未加星标

JavaScript中的call 和apply的用途以及区别

字体大小 | |
[前端(javascript) 所属分类 前端(javascript) | 发布者 店小二05 | 时间 2017 | 作者 红领巾 ] 0人收藏点击收藏
javascript中的call 和apply的用途以及区别

5小时前来源:cnblogs

apply 接受两个参数,第一个参数指定了函数体内this 对象的指向,第二个参数为一个带下
标的集合,这个集合可以为数组,也可以为类数组,apply 方法把这个集合中的元素作为参数传
递给被调用的函数: 在这段代码中,参数 1、2、3 被放在数组中一起传入func 函数,它们分别对应func 参数列
表中的a、b、c。 call 传入的参数数量不固定,跟apply 相同的是,第一个参数也是代表函数体内的this 指向,
从第二个参数开始往后,每个参数被依次传入函数: var func = function( a, b, c ){ alert ( [ a, b, c ] ); // 输出 [ 1, 2, 3 ]}; func.call( null, 1, 2, 3 );

当调用一个函数时,JavaScript 的解释器并不会计较形参和实参在数量、类型以及顺序上的

区别,JavaScript 的参数在内部就是用一个数组来表示的。从这个意义上说,apply 比call 的使用

率更高,我们不必关心具体有多少参数被传入函数,只要用apply 一股脑地推过去就可以了。

call 是包装在apply 上面的一颗语法糖,如果我们明确地知道函数接受多少个参数,而且想

一目了然地表达形参和实参的对应关系,那么也可以用call 来传送参数。

call和apply的用途

1. 改变this 指向
call 和apply 最常见的用途是改变函数内部的this 指向,我们来看个例子:

var obj1 = { name: 'sven' }; var obj2 = { name: 'anne' }; window.name = 'window'; var getName = function{ alert ( this.name ); }; getName; // 输出: window getName.call( obj1 ); // 输出: sven getName.call( obj2 ); // 输出: anne

当执行getName.call( obj1 )这句代码时,getName 函数体内的this 就指向obj1 对象,所以
此处的 var getName = function{
alert ( this.name );
}; 实际上相当于:
var getName = function{
alert ( obj1.name ); // 输出: sven
}; 在实际开发中,经常会遇到this 指向被不经意改变的场景,比如有一个div 节点,div 节点
的onclick 事件中的this 本来是指向这个div 的: 假如该事件函数中有一个内部函数func,在事件内部调用func 函数时,func 函数体内的this
就指向了window,而不是我们预期的div,见如下代码:

这时候我们用call 来修正func 函数内的this,使其依然指向div:

2. Function.prototype.bind

大部分高级浏览器都实现了内置的Function.prototype.bind,用来指定函数内部的this 指向,
即使没有原生的Function.prototype.bind 实现,我们来模拟一个也不是难事,代码如下: 我们通过Function.prototype.bind 来“包装”func 函数,并且传入一个对象context 当作参
数,这个context 对象就是我们想修正的this 对象。 在Function.prototype.bind 的内部实现中,我们先把func 函数的引用保存起来,然后返回一
个新的函数。当我们在将来执行func 函数时,实际上先执行的是这个刚刚返回的新函数。在新
函数内部,self.apply( context, arguments )这句代码才是执行原来的func 函数,并且指定context
对象为func 函数体内的this。 这是一个简化版的Function.prototype.bind 实现,通常我们还会把它实现得稍微复杂一点,
使得可以往func 函数中预先填入一些参数:

本文前端(javascript)相关术语:javascript是什么意思 javascript下载 javascript权威指南 javascript基础教程 javascript 正则表达式 javascript设计模式 javascript高级程序设计 精通javascript javascript教程

分页:12
转载请注明
本文标题:JavaScript中的call 和apply的用途以及区别
本站链接:http://www.codesec.net/view/522720.html
分享请点击:


1.凡CodeSecTeam转载的文章,均出自其它媒体或其他官网介绍,目的在于传递更多的信息,并不代表本站赞同其观点和其真实性负责;
2.转载的文章仅代表原创作者观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,本站对该文以及其中全部或者部分内容、文字的真实性、完整性、及时性,不作出任何保证或承若;
3.如本站转载稿涉及版权等问题,请作者及时联系本站,我们会及时处理。
登录后可拥有收藏文章、关注作者等权限...
技术大类 技术大类 | 前端(javascript) | 评论(0) | 阅读(43)