js中apply与call简单用法详解


Posted in Javascript onNovember 06, 2017

你可以直接看例子,也可以先读一下介绍:

call和apply是为了动态改变this而出现的,当一个object没有某个方法,但是其他的有,我们可以借助call或apply用其它对象的方法来操作。

call, apply都属于Function.prototype的一个方法,它是JavaScript引擎内在实现的,因为属于Function.prototype,所以每个Function对象实例,也就是每个方法都有call, apply属性.既然作为方法的属性,那它们的使用就当然是针对方法的了.这两个方法是容易混淆的,因为它们的作用一样,只是使用方式不同.
从上面可以得出 call, apply 是给方法使用的,为了改变调用该方法的 this指针

简单例子:

call

function A() {
  this.getName = function (xx) {
    return xx;
  }
}

function B() {

}

var a = new A();
console.log( a.getName('i am A') ); //i am A

var b = new B() ;
console.log( a.getName.call(b,'i am B') ); // i am B

B 函数中没有 任何方法 , A 函数有个 getName() 方法 ,a.getName() 自然成立 ,但 B 也要使用 getName() 的方法怎么办呢 ? 那就用 call(this,'参数') !!

可以 再理解一下这句话 -- 我们可以借助call或apply调用其它对象的方法来操作,call和apply是为了动态改变this而出现的 ,本来 a.getName() 的 this 指向 a, call 动态的 把 this 指向了 b ,变成了 b.getName()

apply

apply 与 call 只是参数的使用不同而已

function A() {
  this.sun = function (a ,b) {
    return a+b;
  }
}

function B() {

}

var a = new A();
console.log( a.sun(1,2) ); //3

var b = new B() ;
console.log( a.sun.call(b,2,2) ); // 4

console.log( a.sun.apply(b,[3, 3]) ); //6

call和apply一般使用情况

用的比较多的,通过document.getElementsByTagName选择的dom 节点是一种类似array的array。它不能应用Array下的push,pop等方法。我们可以通过:

var domNodes = Array.prototype.slice.call(document.getElementsByTagName("*"));

这样domNodes就可以应用Array下的所有方法了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JS常用正则表达式总结
Nov 12 Javascript
JavaScript常用验证函数实例汇总
Nov 25 Javascript
javascript转换日期字符串为Date日期对象的方法
Feb 13 Javascript
简单谈谈javascript Date类型
Sep 06 Javascript
基于replaceChild制作简单的吞噬特效
Sep 21 Javascript
asp.net+jquery.form实现图片异步上传的方法(附jquery.form.js下载)
May 05 Javascript
使用AngularJS2中的指令实现按钮的切换效果
Mar 27 Javascript
vue.js在标签属性中插入变量参数的方法
Mar 06 Javascript
vue2.0实现移动端的输入框实时检索更新列表功能
May 08 Javascript
vue 自定义提示框(Toast)组件的实现代码
Aug 17 Javascript
webpack.DefinePlugin与cross-env区别详解
Feb 23 Javascript
使用js原生实现年份轮播选择效果实例
Jan 12 Javascript
js实现简单数字变动效果
Nov 06 #Javascript
利用百度地图API获取当前位置信息的实例
Nov 06 #Javascript
原生js封装添加class,删除class的实例
Nov 06 #Javascript
Node.js实现发送邮件功能
Nov 06 #Javascript
快速搭建React的环境步骤详解
Nov 06 #Javascript
基于Two.js实现星球环绕动画效果的示例
Nov 06 #Javascript
two.js之实现动画效果示例
Nov 06 #Javascript
You might like
总集篇&特番节目先行播出!《SAO Alicization War of Underworld》第2季度TV动画4月25日放送!
2020/03/06 日漫
PHP缓存技术的使用说明
2011/08/06 PHP
php数组函数序列之in_array() - 查找数组中是否存在指定值
2011/11/07 PHP
10个对初学者非常有用的PHP技巧
2016/04/06 PHP
javascript调试说明
2010/06/07 Javascript
onsubmit阻止form表单提交与onclick的相关操作
2010/09/03 Javascript
jQuery数组处理方法汇总
2011/06/20 Javascript
JS自动适应的图片弹窗实例
2013/06/29 Javascript
分享有关jQuery中animate、slide、fade等动画的连续触发、滞后反复执行的bug
2016/01/10 Javascript
Angularjs中三种数据的绑定策略(“@”,“=”,“&”)
2016/12/23 Javascript
jQuery插件echarts实现的单折线图效果示例【附demo源码下载】
2017/03/04 Javascript
简单好用的nodejs 爬虫框架分享
2017/03/26 NodeJs
ES6使用let命令更简单的实现块级作用域实例分析
2017/03/31 Javascript
webpack中的热刷新与热加载的区别
2018/04/09 Javascript
js实现多个倒计时并行 js拼团倒计时
2019/02/25 Javascript
JavaScript高阶教程之“==”隐藏下的类型转换
2019/04/11 Javascript
JavaScript实现Tab选项卡切换
2020/02/13 Javascript
jquery绑定事件 bind和on的用法与区别分析
2020/05/22 jQuery
vue项目接口管理,所有接口都在apis文件夹中统一管理操作
2020/08/13 Javascript
[01:11:28]DOTA2-DPC中国联赛定级赛 RNG vs Phoenix BO3第一场 1月8日
2021/03/11 DOTA
分析在Python中何种情况下需要使用断言
2015/04/01 Python
python实现搜索本地文件信息写入文件的方法
2016/02/22 Python
Python使用Redis实现作业调度系统(超简单)
2016/03/22 Python
python之matplotlib学习绘制动态更新图实例代码
2018/01/23 Python
python3实现基于用户的协同过滤
2018/05/31 Python
CSS3的颜色渐变效果的示例代码
2017/09/29 HTML / CSS
html通过canvas转成base64的方法
2019/07/18 HTML / CSS
森海塞尔美国官网:Sennheiser耳机与耳麦
2017/07/19 全球购物
西班牙手机之家:Phone House
2018/10/18 全球购物
试用期员工考核制度
2014/01/22 职场文书
汽车广告策划方案
2014/05/31 职场文书
小学教师师德师风演讲稿
2014/08/22 职场文书
2014年安置帮教工作总结
2014/12/11 职场文书
乌镇导游词
2015/02/02 职场文书
汽车销售助理岗位职责
2015/04/14 职场文书
2015银行年终工作总结范文
2015/05/26 职场文书