JQuery,从嵌套属性中访问对象的根属性
JQuery, access root property of an object from within the nested property
我有一个对象,它列出了一系列验证规则,如下所示。
validation_rules = {
'validate_rule1' : {
'rule' : function(el){
do something
if(true){
this.message = 'this is a numeric error';
}
return true;
},
'message' : 'this is a general error';
},
'validate_rule2' : {
'rule' : function(el){
do something
return this.variation.variation_1(el);
},
'message' : 'this is a general error',
'variation' : {
'variation_1' : function(el){
return true/false;
}
}
}
}
该对象由执行规则的函数使用,以确定输入是否有效,并为每个失败的规则返回适当的消息。
我知道如何为每个规则设置一个默认消息,并像在rule1中那样使用实例"this"覆盖它。
我可以重写rule2的消息,将实例作为函数的参数传递给每个变体。
我想知道,有没有一种方法可以将"this"的范围向上移动以访问"validate_rule2"属性?
在调用函数variation_1
时,可以使用javascript call
函数传递父级的作用域,也可以传递任何可能需要的作用域。
fun.call(thisArg[, arg1[, arg2[, ...]]])
使用第一个参数,可以设置函数的this
对象
https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Function/call
相关文章:
- 为什么我可以在Array属性对象中找到Javascript Array for Each方法
- 使用onclick调用属性对象函数
- 嵌套为..in 循环,列出多维对象的属性(对象)
- 动态属性对象 - JSON
- 在不使用隔离范围angularjs自定义指令的情况下获取属性对象
- 通过属性传递属性/对象.Javascript
- Javascript:属性/对象的类型
- 访问JSON中的属性(对象)
- 属性对象Javascript不是用Jquery Deferred设置的
- 无法读取属性'#<对象>'未定义的获取错误
- Twitter中多属性对象的子字符串匹配
- 无法设置'data'属性'对象'标记.(只IE8)
- 更新数据属性对象属性值
- 将属性对象的选定对象从原型推入数组
- 将单个属性对象字面量的数组转换为仅包含其值的数组的最佳方法
- 寻找一种更简单的方法来检查是否多个属性&对象中的方法是未定义的
- 主干模型:带有get方法的空属性,但在属性对象中
- 如何赋值给"text"someText"属性对象在动能js
- Angularjs的数据绑定与数据属性对象
- 如何将一个嵌套的javascript对象转换为只有一级属性对象