function A(params) {
params = params || {};
for(var key in params){
Object.defineProperty(this, key, {
get : function() {
return params[key]
},
enumerable : false
});
}
}
var a = new A({
'x' : 'X',
'y' : 'Y',
'z' : 'Z'
})
console.log(a.x);
Le résultat est Z, ce qui est un peu difficile à comprendre. L'exemple de sortie de la console est le suivant :
La raison est en fait très simple, le problème réside dans la boucle for
La clé finale ici === 'z', et les résultats des autres attributs renvoient params[key], c'est-à-dire params['z']
Il s'agit d'une fonction de copie d'objet. La seule différence par rapport à l'objet original est que les attributs de l'objet copié a ne peuvent pas être parcourus à l'aide d'une boucle for. En raison de la fermeture, les clés appelées par la fonction get sont toutes z. = {
}Créez une fermeture ou utilisez let
Ou changez la clé var en clé let
Ici,
Object.defineProperty(this, key, {})
Lakey
ici est lue et utilisée immédiatement, c'est donc le comportement attendux,y, z
Object.defineProperty(this, key, {})
这里的key
是立即读取使用的,所以是预期行为x,y,z
这个函数是未来的一个时间点执行的,所以运行的时候读取的是最后的
Cette fonction est exécutée à un moment dans le futur, donc lors de son exécution, elle lit la dernière valeurkey
值,即z
clé
, qui estz
. C'est la même chose que le problème de fermeture classique.rrreee
Tout ce qui est imprimé est 5. 🎜