JavaScript动态定义属性
JavaScript dynamically defining properties
我正在开发一个JS框架,遇到了一些奇怪的东西(或者我错过了完全明显的东西)
我使用Object.defineProperty
定义对象的属性。然而,在for循环中使用它会产生一些奇怪的值。不知何故,添加的最后一个属性将始终是指定的值。例如,如果我将某个东西分配给属性one
,它将被分配给属性three
。这是一个例子(还有一把小提琴http://jsfiddle.net/5xLdC/)
var Test = function(){};
var props = ['one', 'two', 'three'];
for(var i = 0; i < props.length; i++) {
Object.defineProperty(Test.prototype, props[i], {
get: function() {
return this['_'+props[i]];
},
set: function(val) {
this['_'+props[i]] = val;
}
});
}
var test = new Test();
test.one = 'one';
console.log(test.three) // => 'one'
如果我把它封装在一个forEach
循环中,它会非常好地工作。我的猜测是,由于作用域错误(就我而言?),它们都持有相同的get
/set
函数。
有人能解释一下为什么会发生这种情况吗?
编辑:
也可以用IIFE解决:
get:(function(y) {
return function() { return this['_'+props[y]]; }
})(i)
get
和set
是所有引用同一变量i
的函数。当您在循环外调用函数时,i
为3。使用forEach
时,定义属性的函数会将索引或键作为参数,这在每次调用中都是不同的实体。
相关文章:
- 使用方法和属性定义javascript对象的最佳方法是什么?(如果可能以本机方式)
- Javascript - 使用数组属性定义对象
- ECMAScript 中的内部属性定义是为了什么
- 为什么不在对象外部使用属性定义语法是语法错误
- ES6 类属性定义
- 为javascript类的属性定义函数
- 属性定义是使用敲除时的方法定义
- 为AngularJS的子属性定义getter setter
- 如何给顶部属性定义在CSS chrome或firefox
- 如何通过两个属性定义元素
- 为什么函数属性定义在对象本身上(例如Function.name),而方法定义在Function.prototype上?
- Javascript原型属性定义为对象
- 停止传播在ASP.Net中使用属性定义的JavaScript事件
- 用不同的属性定义同一个Grunt Task两次
- AngularJS:在隔离范围内获取属性定义指令的值
- 需要另一个使用属性定义控制器的指令的角度指令
- 基于其他属性定义对象属性值
- 如何将属性定义为变量
- 奇怪的javascript属性定义使用聚合物
- fabric.js -如果属性定义在new fabric.Circle()括号之外,则Circle不起作用