最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

JavaScript中函数(Function)的apply与call理解_javascript技巧

来源:动视网 责编:小采 时间:2020-11-27 21:40:31
文档

JavaScript中函数(Function)的apply与call理解_javascript技巧

JavaScript中函数(Function)的apply与call理解_javascript技巧:JavaScript函数调用分为4中模式: 1. 方法调用模式:即对象包含方法属性,Obj.methodName()或者Obj[methodName]()。 2. 函数调用模式:即methodName()。 3. 构造器调用模式:即new MethodName()。 4. apply和call调用模式:即Obj
推荐度:
导读JavaScript中函数(Function)的apply与call理解_javascript技巧:JavaScript函数调用分为4中模式: 1. 方法调用模式:即对象包含方法属性,Obj.methodName()或者Obj[methodName]()。 2. 函数调用模式:即methodName()。 3. 构造器调用模式:即new MethodName()。 4. apply和call调用模式:即Obj


JavaScript函数调用分为4中模式:

1. 方法调用模式:即对象包含方法属性,Obj.methodName()或者Obj[methodName]()。
2. 函数调用模式:即methodName()。
3. 构造器调用模式:即new MethodName()。
4. apply和call调用模式:即ObjA.apply(ObjB,args[])或者ObjA.call(ObjB,arg1,arg2...)。

函数调用时,除了接收形式参数外,还会接收this和arguments。其中this为函数对象上下文,arguments为实际参数。
apply和call实现同样的功能,即切换函数对象的上下文(this指向的引用),区别在于形式参数不一样。apply为arguments或者数组,call为以逗号隔开多个单独形式参数。


在执行add.call(test,3); 之前add和test都属于window下,此时this指向window。add.call(test,3); 执行时,进入add方法体,此时this由window切换为test,此时this.a=test.a,this.b=test.b,c为形式参数传入的值,即alert()的结果为1+2+3=6。apply也是一样的功能。

通过apply和call实现扩展和继承:

结果为cat=Cat{name:"Black Cat",showName: function(){ alert(this.name);}, cat.showName();//执行时this由window切换为 //Cat{name:"Black Cat",showName: function(){ alert(this.name);} 此时this.name //为this.name=Cat.name,因此为Black Cat。

文档

JavaScript中函数(Function)的apply与call理解_javascript技巧

JavaScript中函数(Function)的apply与call理解_javascript技巧:JavaScript函数调用分为4中模式: 1. 方法调用模式:即对象包含方法属性,Obj.methodName()或者Obj[methodName]()。 2. 函数调用模式:即methodName()。 3. 构造器调用模式:即new MethodName()。 4. apply和call调用模式:即Obj
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top