JavaScript中神奇的call()方法


Posted in Javascript onMarch 12, 2015

先看看关于call()的官方解释,“调用一个对象的一个方法,以另一个对象替换当前对象。”,看了这样的解释,或许让你更摸不着头脑了。看例子:

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 相关文章推荐
浅析jquery ajax异步调用方法中不能给全局变量赋值的原因及解决方法
Jan 10 Javascript
JQuery弹出炫丽对话框的同时让背景变灰色
May 22 Javascript
分享两款带遮罩的jQuery弹出框
Dec 30 Javascript
浅谈JS继承_借用构造函数 & 组合式继承
Aug 16 Javascript
JS原型链 详解及示例代码
Sep 06 Javascript
微信小程序 获取微信OpenId详解及实例代码
Oct 31 Javascript
详解vue前后台数据交互vue-resource文档
Jul 19 Javascript
Bootstrap Table 在指定列中添加下拉框控件并获取所选值
Jul 31 Javascript
微信小程序实现多个按钮的颜色状态转换
Feb 15 Javascript
Vue渲染过程浅析
Mar 14 Javascript
JavaScript console的使用方法实例分析
Apr 28 Javascript
在vue中使用el-tab-pane v-show/v-if无效的解决
Aug 03 Javascript
jquery实现无限分级横向导航菜单的方法
Mar 12 #Javascript
JavaScript中定义函数的三种方法
Mar 12 #Javascript
javascript实时显示北京时间的方法
Mar 12 #Javascript
jquery实现焦点图片随机切换效果的方法
Mar 12 #Javascript
JavaScript数据结构与算法之栈详解
Mar 12 #Javascript
jQuery实现简单的日期输入格式化控件
Mar 12 #Javascript
Javascript数据结构与算法之列表详解
Mar 12 #Javascript
You might like
MVC模式的PHP实现
2006/10/09 PHP
如何做到多笔资料的同步
2006/10/09 PHP
php获取根域名方法汇总
2014/10/28 PHP
PHP中如何判断exec函数执行成功?
2016/08/04 PHP
Laravel框架实现利用监听器进行sql语句记录功能
2018/06/06 PHP
php使用自带dom扩展进行元素匹配的原理解析
2020/05/29 PHP
JS 动态加载脚本的4种方法
2009/05/05 Javascript
jQuery获取地址栏参数插件(模仿C#)
2010/10/26 Javascript
javascript实现可改变滚动方向的无缝滚动实例
2013/06/17 Javascript
js键盘上下左右键怎么触发function(实例讲解)
2013/12/14 Javascript
iframe实用操作锦集
2014/04/22 Javascript
javascript的push使用指南
2014/12/05 Javascript
nodejs事件的监听与触发的理解分析
2015/02/12 NodeJs
js实现分享到随页面滚动而滑动效果的方法
2015/04/10 Javascript
快速掌握Node.js环境的安装与运行方法
2016/02/16 Javascript
基于jquery实现智能表单验证操作
2016/05/09 Javascript
检查表单元素的值是否为空的实例代码
2016/06/16 Javascript
JS实现的自定义水平滚动字体插件完整实例
2016/06/17 Javascript
总结Javascript中的隐式类型转换
2016/08/24 Javascript
浅谈ES6新增的数组方法和对象
2017/08/08 Javascript
详解vue渲染函数render的使用
2017/12/12 Javascript
Angular实现的自定义模糊查询、排序及三角箭头标注功能示例
2017/12/28 Javascript
jquery分页插件pagination使用教程
2018/10/23 jQuery
JS动画实现回调地狱promise的实例代码详解
2018/11/08 Javascript
在Python中处理日期和时间的基本知识点整理汇总
2015/05/22 Python
利用Python抓取行政区划码的方法
2016/11/28 Python
基于pycharm实现批量修改变量名
2020/06/02 Python
美国畅销的跑步机品牌:ProForm
2017/02/06 全球购物
美国独家设计师眼镜在线光学商店:Glasses Gallery
2017/12/28 全球购物
美国伴娘礼服商店:Evening Collective
2019/10/07 全球购物
教育孩子心得体会
2014/01/01 职场文书
消防先进事迹材料
2014/02/10 职场文书
预防艾滋病宣传活动总结
2015/05/09 职场文书
爱岗敬业事迹材料
2019/06/20 职场文书
对Keras自带Loss Function的深入研究
2021/05/25 Python
pytorch fine-tune 预训练的模型操作
2021/06/03 Python