在JavaScript中定义自定义对象和函数(第2部分)
Defining custom objects and functions in JavaScript (Part 2)
根据我之前问的一个问题,我将如何限定这个字符串。。。
"MyCustomObject.prototype.foo.bar"
到此:
window['MyCustomObject']['prototype']['foo']['bar']
以对象形式?(它一定没有资格…
"window['MyCustomObject']['prototype']['foo']['bar']"
作为字符串!)。
作为参考,请考虑以下内容。。。(代码错误…需要修复(没有eval关键字))
var fn = "MyCustomObject.prototype.foo.bar";
var ptr = fn.split('.');
var ptrPath = 'window'
for(var index = 0; index < ptr.length; index++) {
ptrPath += '[''' + ptr[index] + ''']';
}
ptrPath = function() {
alert("Hello");
}
应该解决这个问题;
var inst = new MyObject();
inst.foo.bar(); //alerts...."Hello"
我修改了这个问题的答案以满足您的需要。
var getPropertyByName = function (fullString, context) {
var namespaces = fullString.split(".");
var functionName = namespaces.pop();
for (var i = 0; i < namespaces.length; i++) {
context = context[namespaces[i]];
}
return context[functionName];
};
getPropertyByName('MyCustomObject.foo.bar', window);
http://jsfiddle.net/jbabey/4GVUK/
您可以尝试以下方式:
var fn = "foo.prototype.bar";
var ptr = fn.split('.');
var func = ptr.reduce(function(a, b){
return a[b] ? a[b] : a;
}, window);
工作演示
经过大量努力,我终于找到了解决方案。
Object.implement函数背后的思想是允许开发人员:
-
通过名称定义对象/函数(例如"Custom"或"Custom.protype.foo.bar"),而不管该对象是否存在。
-
定义对象/功能上下文(E.G窗口)
-
定义对象/功能实现
-
定义如果实现已经存在,是否覆盖对象/函数。
考虑Object.implement代码示例:
Object.implement = function(fn, context, implementation, override) {
var properties = fn.split('.');
var fnName = properties.pop();
for(var index = 0; index < properties.length; index++) {
if(!context[properties[index]]) {
context[properties[index]] = { };
}
context = context[properties[index]];
}
if(!context[fnName] || override) {
context[fnName] = implementation;
}
};
我现在可以使用它来安全地创建/实现对象和函数。考虑一下这有点像一个"垫片"功能,如果一个功能不存在,就可以提供一个实现,但添加了现有功能后,现有功能也可能被覆盖:
Object.implement("HashTable", window, function() { }, true);
Object.implement("HashTable.prototype.bar", window, function() { alert("Hello World") }, true);
var ht = new HashTable();
ht.bar();
它适用于FireFox。。。我还没有在其他浏览器中进行测试!
相关文章:
- 创建一个类似链接的按钮,并通过Javascript函数打开一个新的弹出窗口
- 将函数的上下文应用于javascript变量
- 如何在JavaScript中将字符串转换为函数引用
- 用嵌套函数和默认函数定义函数
- 使用 jQuery 的 .on 函数如何获取事件的原始元素
- 无法导出函数expressjs/requestjs中的变量
- 函数参数中的数据与指定变量之间的任何性能差异
- JQuery合并了keyup和focusout两个函数
- ES6构造函数返回基类的实例
- 监视函数从服务返回不起作用,但作用域函数起作用
- 我可以在json对象中添加一个函数吗
- AngularJS:我可以跳过函数参数回调吗
- 如何使jQuery插件函数可调用以供独立使用,而不在集合上操作
- JavaScript数组排序(函数)用于对表行进行排序,而不是排序
- jquery点击函数select&取消选择
- 拨打'父亲'函数形式a'儿童'ReactJS中的组件
- Node.js v6.2.0类扩展不是函数错误
- 比较从函数和生成的日期对象
- Javascript -如何从函数返回部分数组
- 在函数体内部使用ajax时,Javascript函数未定义错误