JavaScript中神奇的call()方法
2015-03-12 00:00
435 查看
先看看关于call()的官方解释,“调用一个对象的一个方法,以另一个对象替换当前对象。”,看了这样的解释,或许让你更摸不着头脑了。看例子:
我的理解是,f.call(new a())就是把函数(其实也是对象)f复制到被调用对象“new a()”下面去解析,事实上和下面这段代码的解析结果一样:
只不过此时变量X的作用域不同而已,咿…看起来好像有点继承的味道哦,难道不是吗?在上例中,f完全被构造函数a的实力对象继承了,如果说这还不足以说明a.call(b)是一种继承模式,那么再看一个更具有继承味道的用法吧。
在这个例子中,只要会使用浏览器的朋友,都能看得出来e完全继承了f的属性和方法,否则是无法解释的,因为在e中并没有定义属性a和b,那么按常理推断在e的实例对象c中,并不会出现这两个属性。
var x = "我是全局变量"; //定义全局变量x function 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); //弹出a c.b(); //弹出b
在这个例子中,只要会使用浏览器的朋友,都能看得出来e完全继承了f的属性和方法,否则是无法解释的,因为在e中并没有定义属性a和b,那么按常理推断在e的实例对象c中,并不会出现这两个属性。
相关文章推荐
- JavaScript中神奇的call()方法
- JavaScript中call和apply方法的区别实例分析
- javascript 的call和apply方法
- javascript之call方法
- JavaScript中的apply()方法和call()方法使用介绍
- JavaScript使用Call和Apply方法实现继承
- javascript中call与apply的使用方法
- javascript中的call和apply方法
- javascript中的call()和apply()方法 厉害了我的哥
- 深入学习JavaScript: apply\call方法
- javascript中call和apply方法
- JavaScript进阶:JS中的call()、apply()和bind方法
- javascripte中call方法与apply方法
- [转]关于javascript中apply()和call()方法的区别
- 【JavaScript】call和apply区别及使用方法
- javascript中apply和call方法比较及其妙用
- Javascript call和apply区别及使用方法
- Javascript中数据类型及其判别方法(typeof instanceof Object.prototype.toSting.call(obj)的区别)
- javascript方法 call()和apply()的用法
- JavaScript中call,apply,bind方法的总结。