神奇的call()
时间:2011-02-20 来源:zhenn
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()”下面去解析,事实上和下面这段代码的解析结果一样:
1 function a(){
2 this.x = "我是在函数类结构a中声明的哦";
3 alert(this.x);
4 }
5 a();
只不过此时变量X的作用域不同而已,咿…看起来好像有点继承的味道哦,难道不是吗?在上例中,f完全被构造函数a的实力对象继承了,如果说这还不足以说明a.call(b)是一种继承模式,那么再看一个更具有继承味道的用法吧。
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
在这个例子中,只要会使用浏览器的朋友,都能看得出来e完全继承了f的属性和方法,否则是无法解释的,因为在e中并没有定义属性a和b,那么按常理推断在e的实例对象c中,并不会出现这两个属性。
相关阅读 更多 +