如何通过匿名函数给对象属性赋值
How to assign a value to object property via anonymous function?
假设我有一个接受参数的函数。
在这种情况下,我使用matchHeight,但我的问题是一般。
我在一个变量中设置了所有的选项,就像这样。
var options = {
byRow: true,
property: 'height',
remove: true,
};
然后传递给函数:
$('.some_class').matchHeight(options);
现在,我希望能够使用函数动态地评估'remove'属性。我猜应该是这样的:
var options = {
byRow: true,
property: 'height',
// remove: true,
remove: function(){ return true; }
};
但是,它不起作用。正确的做法是什么?更新:更清楚。matchHeight将remove作为布尔属性,而不是函数。
我的主要对象是使用函数"模拟"布尔值,如remove: true
。
如果options.remove
是一个函数,那么您必须实际调用它:
options.remove()
如果你想让这个工作只与options.remove
,你必须定义一个getter属性:
var options = {
byRow: true,
property: 'height'
};
Object.defineProperty(options, 'remove', {
get: function () { return true; }
});
console.log(options.remove);
您的方法应该有效-请参阅以下代码片段:
var options = {
byRow: true,
property: 'height',
// remove: true,
remove: function(){ return true; }
};
function myFunc(options) {
console.log(options.remove())
}
myFunc(options)
相关文章:
- 如何从对象的原型方法访问JavaScript对象属性
- 如何将数组项添加到对象属性中
- 设置嵌套对象属性的更好方法
- JavaScript管理具有重复属性名称的对象属性
- 如何使用element.myobj.prop等具有对象属性的元素
- 如何使用(this)访问Angular 2 http rxjs catch函数中的对象属性
- Es6:能够在设置/更新/删除对象属性时调用自定义方法
- 如何在AngularJS工厂中正确声明对象属性
- 如何使用object.assign()从其他对象引用基本对象属性
- 使用XPath样式访问Javascript JSON对象属性
- 将javascript对象(属性+值)合并到一个对象中
- 数组:使对象属性成为数组键
- 无法从JavaScript中的函数调用对象属性
- Google Closure Advanced |无法识别对象属性|动态属性
- Javascript从匿名函数访问外部对象属性
- 从函数更改对象属性
- 如何从字符串变量访问对象属性
- 从嵌套对象属性中获取排除某个值的最高值
- 在Aurelia computeds中,当设置依赖关系时,如何声明对对象属性的依赖关系
- 传递数量不确定的可能嵌套的对象属性