JavaScript中的方法重载实例_javascript技巧
程序员文章站
2022-05-16 18:30:28
...
.NET里面的方法重载用着的确很方便,哪Javascript里面能不能也哪样做呢?
var showMessage = function(name,value,id){
if(id != ”undefined”){
alert(name+value+id);
}
else if(value != ”undefined”){
alert(name + value);
}
else{
alert(name);
}
}
// addMethod - By John Resig (MIT Licensed)
function addMethod(object, name, fn){
var old = object[ name ];
object[ name ] = function(){
if ( fn.length == arguments.length ){
return fn.apply( this, arguments );
}
else if ( typeof old == 'function' ){
return old.apply( this, arguments );
}
}
};
看,这样一来就简单了……
Javasciprt里面本生是没有方法重载的功能,以前很多人的做法可能是直接少传参数过去,然后在根据参数是否为 “undefined” 未定义来决定怎么处理,从而实现类似方法重载的功能。
例如:
复制代码 代码如下:
var showMessage = function(name,value,id){
if(id != ”undefined”){
alert(name+value+id);
}
else if(value != ”undefined”){
alert(name + value);
}
else{
alert(name);
}
}
showMessage(”哈哈”);
showMessage(”哈哈”,”??”);
showMessage(”哈哈”,”??”,124124);
今天在Ajaxian上面看到了一篇关于Javascript方法重载的写法,它是能过另外一个方法来实现的。
看一下这个代码:
复制代码 代码如下:
// addMethod - By John Resig (MIT Licensed)
function addMethod(object, name, fn){
var old = object[ name ];
object[ name ] = function(){
if ( fn.length == arguments.length ){
return fn.apply( this, arguments );
}
else if ( typeof old == 'function' ){
return old.apply( this, arguments );
}
}
};
var UserInfo = function(){
addMethod(this,”find”,function(){
alert(”没有参数”);
});
addMethod(this,”find”,function(name){
alert(”传入的参数是一个,叫 ”+name);
});
addMethod(this,”find”,function(name,value){
alert(”传入了两个参数,一个叫 name=”+name+” 一个叫 value=”+value);
});
};
var userinfo = new UserInfo();
userinfo.find();
userinfo.find('我是谁?');
userinfo.find('某某某','1512412514');
看,这样一来就简单了……
推荐阅读
-
Javascript中的getUTCDay()方法使用详解
-
简介JavaScript中的setDate()方法的使用
-
在JavaScript中操作时间之getUTCDate()方法的使用
-
JavaScript中的getTime()方法使用详解
-
JavaScript中setMonth()方法的使用详解
-
JavaScript中的getTimezoneOffset()方法使用详解
-
Javascript中的getUTCHours()方法使用详解
-
JavaScript中getUTCMinutes()方法的使用详解
-
在JavaScript中处理时间之setMinutes()方法的使用
-
简介JavaScript中的getUTCFullYear()方法的使用