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 相关文章推荐
javascript-表格排序(降序/反序)实现介绍(附图)
May 30 Javascript
js将控件隐藏的方法及display属性介绍
Jul 04 Javascript
Js的Array数组对象详解
Feb 22 Javascript
js canvas实现擦除效果示例代码
Apr 26 Javascript
React入门教程之Hello World以及环境搭建详解
Jul 11 Javascript
php register_shutdown_function函数详解
Jul 23 Javascript
JavaScript实现旋转轮播图
Aug 18 Javascript
javascript 中事件冒泡和事件捕获机制的详解
Sep 01 Javascript
让webpack+vue-cil项目不再自动打开浏览器的方法
Sep 27 Javascript
在vue中使用vuex,修改state的值示例
Nov 08 Javascript
vue 组件基础知识总结
Jan 26 Vue.js
使用JS实现简易计算器
Jun 14 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
深入php数据采集的详解
2013/06/02 PHP
使用php测试硬盘写入速度示例
2014/01/27 PHP
PHP判断文件是否被引入的方法get_included_files用法示例
2016/11/29 PHP
PHP编程实现的TCP服务端和客户端功能示例
2018/04/13 PHP
JQuery 获得绝对,相对位置的坐标方法
2010/02/09 Javascript
使用Jquery打造最佳用户体验的登录页面的实现代码
2011/07/08 Javascript
Js实现当前点击a标签变色突出显示其他a标签回复原色
2013/11/27 Javascript
jQuery.holdReady()使用方法
2014/05/20 Javascript
JS实现简单的图书馆享元模式实例
2015/06/30 Javascript
JS中多步骤多分步的StepJump组件实例详解
2016/04/01 Javascript
输入框点击时边框变色效果的实现方法
2016/12/26 Javascript
js点击任意区域弹出层消失实现代码
2016/12/27 Javascript
JQuery validate 验证一个单独的表单元素实例
2017/02/17 Javascript
基于JavaScript实现移动端无限加载分页
2017/03/27 Javascript
vue.js简单配置axios的方法详解
2017/12/13 Javascript
详解如何快速配置webpack多入口脚手架
2018/12/28 Javascript
Vue中Axios从远程/后台读取数据
2019/01/21 Javascript
基于node+websocket+html实现腾讯课堂聊天室聊天功能
2020/03/04 Javascript
原生js实现随机点名
2020/07/05 Javascript
[04:27]2014DOTA2国际邀请赛 NAVI战队官方纪录片
2014/07/21 DOTA
[02:04]2014DOTA2国际邀请赛 DK一个时代的落幕
2014/07/21 DOTA
[00:12]2018DOTA2亚洲邀请赛 Somnus丶M出阵单挑
2018/04/06 DOTA
Python 16进制与中文相互转换的实现方法
2018/07/09 Python
Python爬虫基础之XPath语法与lxml库的用法详解
2018/09/13 Python
pandas分区间,算频率的实例
2019/07/04 Python
python如何使用Redis构建分布式锁
2020/01/16 Python
tensorflow 实现自定义layer并添加到计算图中
2020/02/04 Python
Python环境配置实现pip加速过程解析
2020/11/27 Python
晚会主持词开场白
2014/03/17 职场文书
2015年宣传部部长竞选演讲稿
2014/11/28 职场文书
2014小学语文教学工作总结
2014/12/17 职场文书
2015年全国保险公众宣传日活动方案
2015/05/06 职场文书
家长会主持词开场白
2015/05/29 职场文书
Redis入门教程详解
2021/08/30 Redis
MySQL中order by的使用详情
2021/11/17 MySQL
python的html标准库
2022/04/29 Python