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

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..

最新文章

  1. c++程序判断系统是Linux还是Windows
  2. silverlight制作虚线的边框
  3. android一句话搞定图片加载
  4. 求sqrt()底层效率问题(二分/牛顿迭代)
  5. HighCharts之2D柱状图
  6. Java final static abstract关键字介绍
  7. 转: Oracle中的物化视图
  8. java的nio之:java的nio系列教程之buffer的概念
  9. java小程序:求完全数
  10. 动画 -- ListView列表item逐个出来(从无到有)
  11. AngularJS - Watch 监听对象
  12. 简洁JS 日历控件 支持日期和月份选择
  13. 苹果充电器USB端的识别电阻的设置
  14. 关于JavaScript中的escape、encodeURI和encodeURIComponent
  15. Sagit.Framework For IOS 开发框架入门开发教程2:一行代码实现引导页
  16. [DeeplearningAI笔记]ML strategy_1_1正交化/单一数字评估指标
  17. 最小公共祖先 (Tarjan) POJ1470
  18. 微服务架构 - SpringCloud整合分布式服务跟踪zipkin
  19. 类StringBuilder
  20. 2.go的变量和常量

热门文章

  1. 用python编写的无线AP扫描器
  2. centos 在CentOS下编译FFmpeg
  3. 【BZOJ2338】[HNOI2011]数矩形 几何
  4. Hibernate表关系映射之一对一映射
  5. 远程访问Linux的常见方式
  6. CentOS 64位 6.4 命令行安装 oracle 11g 客户端
  7. CentOS(Linux) - 安装软件笔记(一) - VPSMate(服务器可视化管理工具)安装
  8. Educational Codeforces Round 9 C. The Smallest String Concatenation —— 贪心 + 字符串
  9. 人生苦短之Python多线程
  10. java后台获取cookie里面值得方法