Would you like to react to this message? Create an account in a few clicks or log in to continue.
搜索
 
 

结果按:
 


Rechercher 高级搜索

关键词

最新主题
» js在html中的加载执行顺序
JS函数调用的四种方法                                 Empty10/09/13, 06:50 am 由 design_ss

» javascript 函数的方法call()和apply()
JS函数调用的四种方法                                 Empty09/09/13, 05:10 am 由 design_ss

» JS中typeof与instanceof的区别
JS函数调用的四种方法                                 Empty08/08/13, 11:10 am 由 design_ss

» JS中的构造函数解析
JS函数调用的四种方法                                 Empty08/08/13, 09:44 am 由 design_ss

» js对象属性方法大总结
JS函数调用的四种方法                                 Empty08/08/13, 08:46 am 由 design_ss

» js中的值类型和引用类型小结 文字说明与实例
JS函数调用的四种方法                                 Empty08/08/13, 06:35 am 由 design_ss

» CSS3中轻松实现渐变效果
JS函数调用的四种方法                                 Empty05/07/13, 09:48 am 由 design_ss

» jQUery 常用实例
JS函数调用的四种方法                                 Empty03/07/13, 09:56 am 由 design_ss

» mask_layer 遮照
JS函数调用的四种方法                                 Empty03/07/13, 08:18 am 由 design_ss

十一月 2024
周一周二周三周四周五周六周日
    123
45678910
11121314151617
18192021222324
252627282930 

日历 日历

合作伙伴
免费论坛

免費論壇




JS函数调用的四种方法

 :: 前端制作 :: js

向下

JS函数调用的四种方法                                 Empty JS函数调用的四种方法

帖子  design_ss 19/12/12, 05:21 am

js的函数调用会免费奉送两个而外的参数就是 this 和 arguments 。arguments是参数组,他并不是一个真实的数组,但是可以使用.length方法获得长度。

书上有说4中调用方式:


  • 方法调用模式
  • 函数调用模式
  • 构造器调用模式
  • apply调用模式

下面我们来看看一些实例更好理解。

1:方法调用模式。

请注意this此时指向myobject。

/*方法调用模式*/
var myobject={
value:0,
inc:function(){
alert(this.value)
}
}
myobject.inc()



2:函数调用模式

请注意this此时指向window

/*函数调用模式*/

var add=function(a,b){
alert(this)//this被绑顶到window
return a+b;
}
var sum=add(3,4);
alert(sum)



3:构造器调用模式

javascript语言精粹一书建议摒弃这中方式。因为有更好的方式。这里先不介绍。下次发表博文的时候贴出来。

会在这里加一个连接。

/*构造器调用模式 摒弃*/

var quo=function(string){
this.status=string;
}
quo.prototype.get_status=function(){
return this.status;
}
var qq=new quo("aaa");
alert(qq.get_status());



4:apply调用模式

==我们可以来看一个更有用的apply实例。看最下面的代码。



/*apply*/
//注意使用了上面的sum函数
//与myobject
//这中调用方式的优点在于可以指向this指向的对象。
//apply的第一个参数就是this指针要指向的对象
var arr=[10,20];
var sum=add.apply(myobject,arr);
alert(sum);



看这个apply真正应用。bind这是一个绑定时间的函数

var bind=function(object,type,fn){
if(object.attachEvent){//IE浏览器
object.attachEvent("on"+type,(function(){
return function(event){
window.event.cancelBubble=true;//停止时间冒泡
object.attachEvent=[fn.apply(object)];//----这里我要讲的是这里
//在IE里用attachEvent添加一个时间绑定以后。
//this的指向不是到object对象本身所以。我们绑定的function里的this.id是无法正常工作的。
//但是如果我们用fn.apply(object)
//这里可以看出我们是把apply的第一个对象也就是this的指向变更给了object所以this.id就变成了
http://object.id 可以正常工作了。

}
})(object),false);
}else if(object.addEventListener){//其他浏览器
object.addEventListener(type,function(event){
event.stopPropagation();//停止时间冒泡
fn.apply(this)
});
}

}
bind(document.getElementById("aaa"),"click",function(){alert(this.id)});

design_ss

帖子数 : 122
积分 : 373
威望 : 0
注册日期 : 11-12-28

返回页首 向下

返回页首


 :: 前端制作 :: js

 
您在这个论坛的权限:
不能在这个论坛回复主题