博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
js的call()通俗解释
阅读量:6165 次
发布时间:2019-06-21

本文共 2329 字,大约阅读时间需要 7 分钟。

[javascript]   
 
  1. var x = "我是全局变量";    //定义全局变量x  
  2. function a(){         //定义函数类结构a    
  3.     this.x = "我是在函数类结构a中声明的哦";      
  4. }  
  5. //定义普通函数,弹出当前指针所包含的变量x的值  
  6. function f(){         
  7.     alert (this.x);  
  8. }  
  9. //返回值为“我是在函数类结构a中声明的哦”  
  10. f.call(new a());  

 

我的理解是,f.call(new a())就是把函数(其实也是对象)f复制到被调用对象“new a()”下面去解析,事实上和下面这段代码的解析结果一样:

 

[javascript]   
 
  1. function a(){  
  2.   this.x = "我是在函数类结构a中声明的哦";  
  3.   alert(this.x);      
  4. }  
  5. a();  

 

只不过此时变量X的作用域不同而已,咿…看起来好像有点继承的味道哦,难道不是吗?在上例中,f完全被构造函数a的实力对象继承了,如果说这还不足以说明a.call(b)是一种继承模式,那么再看一个更具有继承味道的用法吧。

 

[javascript]   
 
  1. function f(){      
  2.     this.a ="a";      
  3.     this.b = function(){      
  4.         alert("b");  
  5.     }  
  6. }  
  7. function e(){      
  8.     f.call(this);       
  9. }  
  10. var c = new e();  
  11. alert(c.a);  //弹出a  
  12. c.b();    //弹出b  

 


 

 

 

jquery--call()&apply()函数

1. 定义

call方法 

语法:call([thisObj[,arg1[,arg2[,[,..argN]]]]]) 
定义:调用一个对象的一个方法,以另一个对象替换当前对象 
说明:call 方法可以用来代替另一个对象调用一个方法。call 方法可将一个函数的对象上下文从初始的上下文改变为由 thisObj 指定的新对象。 
如果没有提供 thisObj 参数,那么 Global 对象被用作 thisObj。

apply方法 

语法:apply([thisObj[,argArray]]) 
定义:应用某一对象的一个方法,用另一个对象替换当前对象。 
说明: 如果 argArray 不是一个有效的数组或者不是 arguments 对象,那么将导致一个 TypeError。 
如果没有提供 argArray 和 thisObj 任何一个参数,那么 Global 对象将被用作 thisObj, 并且无法被传递任何参数。

2. 常用示例

function add(a,b)  {      alert(a+b);  }  function sub(a,b)  {     alert(a-b);  }  add.call(sub,3,1);

 

用 add 来替换 sub,add.call(sub,3,1) == add(3,1) ,所以运行结果为:alert(4); // 注意:js 中的函数其实是对象,函数名是对 Function 对象的引用。

function Animal(){ this.name = "Animal"; this.showName = function(){ alert(this.name); } } function Cat(){ this.name = "Cat"; } var animal = new Animal(); var cat = new Cat(); //通过call或apply方法,将原本属于Animal对象的showName()方法交给对象cat来使用了。 //输入结果为"Cat" animal.showName.call(cat,","); //animal.showName.apply(cat,[]); 把 animal 的方法放到cat上执行,原来cat是没有showName() 方法,现在是把animal 的showName()方法放到 cat上来执行,所以this.name 应该是 Cat

3.实现继承

function Animal(name){ this.name = name; this.showName = function(){ alert(this.name); } } function Cat(name){ Animal.call(this, name); } var cat = new Cat("Black Cat"); cat.showName();
Animal.call(this) 的意思就是使用 Animal对象代替this对象,那么 Cat中不就有Animal的所有属性和方法了吗,Cat对象就能够直接调用Animal的方法以及属性了.

4.多重继承

function Class10() { this.showSub = function(a,b) { alert(a-b); } } function Class11() { this.showAdd = function(a,b) { alert(a+b); } } function Class2() { Class10.call(this); Class11.call(this); }

当然,js的继承还有其他方法,例如使用原型链,这个不属于本文的范畴,只是在此说明call 的用法。说了call ,当然还有 apply,这两个方法基本上是一个意思,区别在于 call 的第二个参数可以是任意类型,而apply的第二个参数必须是数组,也可以是arguments 

还有 callee,caller..

转载地址:http://vpyba.baihongyu.com/

你可能感兴趣的文章
Symantec NetBackup 7
查看>>
Citrix桌面虚拟化总结
查看>>
我的友情链接
查看>>
Struts 2文件上传
查看>>
centos 7 安装NTP服务
查看>>
CentOS 搭建Apache+Subversion
查看>>
mysql基本操作
查看>>
POJ 2299 Ultra-QuickSort 求逆序数 线段树或树状数组 离散化
查看>>
从事网络工作5年+ 随感
查看>>
SHELL实战day1
查看>>
EditPlus支持SQL突出显示,Shane版,市面最佳
查看>>
Windows 7 中windows update失败还原更改解决方法
查看>>
我的友情链接
查看>>
微软私有云系列-----创建计划
查看>>
logstash grok使用案例
查看>>
hadoop伪分布式部署
查看>>
关于C# -WINFORM-DataGridView的更新、删除
查看>>
【Android进阶学习】监听EditText的变化
查看>>
gulp 插件之 del
查看>>
vim configure
查看>>