添加JavaScript重载函数的辅助方法2
2010-07-04 00:00
567 查看
代码依然简单。所以依然没什么好解释的。。
下面是示例:
/** KOverLoad 一个创建重载函数的辅助方法。 补充上次的函数。 @Author ake 2010-07-03 @weblog http://www.cnblogs.com/akecn */ var KOverLoad = function(scope) { this.scope = scope || window; //默认添加方法到这个对象中。同时添加的方法的this指向该对象。 this.list = {}; //存放重载函数的地方。 return this; }; KOverLoad.prototype = { //添加一个重载的方法。 //@param arg<Function> 重载的方法。 add:function(arg, types) { if(typeof arg == "function") { var types = (types || []).join(","); this.list[arg.length + types] = arg; //以参数数量和类型做标识存储重载方法。很显然如果你的重载方法参数数量 return this; } }, checkTypes: function(types) { var type = []; //console.log(typeof type); []方式创建的数组,其typeof类型为object //如果需要判断类型的话 还是用Object.prototype.toString.call(type) == "[object Array]"来判断吧。 for(var i=0, it; it = types[i++];) { type.push(typeof it); } return type.join(","); }, //添加完所有的重载函数以后,调用该方法来创建重载函数。 //@param fc<String> 重载函数的方法名。 load:function(fc) { var self = this, args, len, types; this.scope[fc] = function() { //将指定作用域的指定方法 设为重载函数。 args = Array.prototype.slice.call(arguments); //将参数转换为数组。 len = args.length; types = self.checkTypes(args); //console.log(self.list); if(self.list[len + types]) { //根据参数数量调用符合的重载方法。 self.list[len + types].apply(self.scope, args); //这里指定了作用域和参数。 }else if(self.list[len]){ self.list[len].apply(self.scope, args) }else { throw new Error("undefined overload type"); } } } };
下面是示例:
var s = {}; new KOverLoad(s) //设置方法绑定的位置。命名空间? .add(function(a) { console.log("one",a,this) },["string"]) .add(function(a,b) { console.log("two",a,b,this) },["string","string"]) .add(function(a,b,c) { console.log("three",a,b,c,this) },["string", "number", "string"]) .add(function(a,b,c,d) { console.log("four",a,b,c,d,this) }) .load("func"); //在这里的参数就是要创建的重载函数的方法名称。 s.func("a","b");
相关文章推荐
- 添加JavaScript重载函数的辅助方法2
- 为JavaScript添加重载函数的辅助方法
- 在javascript中实现OO,通过prototype为类型添加方法,好像继承
- Javascript页面添加到收藏夹的简单方法
- 在Javascript中为String对象添加trim,ltrim,rtrim方法
- 利用JavaScript中的原型给对像添加方法
- JavaScript实现添加及删除事件的方法小结
- 在Javascript中为String对象添加trim,ltrim,rtrim方法
- JavaScript实现动态添加,删除行的方法实例详解
- 关于HTML元素的Table控件javascript添加删除表中行列的方法!
- JavaScript使用push方法添加一个元素到数组末尾用法实例
- 单个未知大小图片在div里面垂直居中的方法。。。添加辅助元素挤一下位置达到居中
- JavaScript添加随滚动条滚动窗体的方法
- FAQ_IE 8中还不支持JavaScript通过appendChild("tr')方法添加Table行
- 通过 prototype 为 JavaScript 的 String 对象添加方法(函数)
- JavaScript中在光标处插入添加文本标签节点的详细方法
- Javascript页面添加到收藏夹的简单方法
- 自定义控件在AJAX的UpdatePanel中使用时添加javascript脚本方法
- javascript给builtin对象添加新方法