JavaScript中神奇的call()方法
来源:互联网 发布:儿童编程培训班加盟 编辑:程序博客网 时间:2024/05/29 17:39
http://www.jb51.net/article/62086.htm
先看看关于call()的官方解释,“调用一个对象的一个方法,以另一个对象替换当前对象。”,看了这样的解释,或许让你更摸不着头脑了。看例子:
复制代码 代码如下:
var x = "我是全局变量"; //定义全局变量xfunction a(){ //定义函数类结构a this.x = "我是在函数类结构a中声明的哦"; }//定义普通函数,弹出当前指针所包含的变量x的值function f(){ alert (this.x);}//返回值为“我是在函数类结构a中声明的哦”f.call(new a());
我的理解是,f.call(new a())就是把函数(其实也是对象)f复制到被调用对象“new a()”下面去解析,事实上和下面这段代码的解析结果一样:
复制代码 代码如下:
function a(){ this.x = "我是在函数类结构a中声明的哦"; alert(this.x); }a();
只不过此时变量X的作用域不同而已,咿…看起来好像有点继承的味道哦,难道不是吗?在上例中,f完全被构造函数a的实力对象继承了,如果说这还不足以说明a.call(b)是一种继承模式,那么再看一个更具有继承味道的用法吧。
复制代码 代码如下:
function f(){ this.a ="a"; this.b = function(){ alert("b"); }}function e(){ f.call(this); }var c = new e();alert(c.a); //弹出ac.b(); //弹出b
在这个例子中,只要会使用浏览器的朋友,都能看得出来e完全继承了f的属性和方法,否则是无法解释的,因为在e中并没有定义属性a和b,那么按常理推断在e的实例对象c中,并不会出现这两个属性。
阅读全文
0 0
- JavaScript中神奇的call()方法
- javascript中call()方法
- javascript 中 方法call()的理解
- javascript 中关于call方法的详解。
- javascript 中关于call方法的详解。
- javascript的call方法
- 关于javascript中apply()和call()方法的区别javascript
- javascript 中call方法解析
- javascript中call方法详解
- javascript中call方法使用
- javascript中call方法使用
- javascript中call方法说明
- Javascript 中神奇的 this
- 关于javascript中apply()和call()方法的区别
- 关于javascript中apply()和call()方法的区别
- 关于javascript中apply()和call()方法的区别
- javascript中apply()和call()方法的区别
- 关于javascript中apply()和call()方法的区别
- JSON.parse()方法,将数据(字符串)转化为javascript对象
- 文档管理Qoppa 商家PDF 系列产品2016R1更新合集
- 利用libevent 和线程池实现高并发服务器的设计
- Bigdecimal类型判断是否等于0(用equals方法的坑)
- QLineEdit
- JavaScript中神奇的call()方法
- Codeforces 520B Two Buttons 题解
- LibLinear使用总结(L1,L2正则)
- Java笔试题解(7)
- Unity 3D
- 单例模式如何传参?
- 爱测未来实习-在讯飞实习下成长
- 洛谷P3765:总统选举 (线段树+treap)
- centos下开启mysql远程服务