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,超强推荐expand.js
Dec 23 Javascript
Javascript中产生固定结果的函数优化技巧
Jan 16 Javascript
js截取字符串的两种方法及区别详解
Nov 05 Javascript
JS实现点击文字对应DIV层不停闪动效果的方法
Mar 02 Javascript
Javascript中this关键字的一些小知识
Mar 15 Javascript
基于css3新属性transform及原生js实现鼠标拖动3d立方体旋转
Jun 12 Javascript
angular.js分页代码的实例
Jul 27 Javascript
vue.js+Element实现表格里的增删改查
Jan 18 Javascript
使用gulp搭建本地服务器并实现模拟ajax
Apr 05 Javascript
Angular2使用Angular CLI快速搭建工程(一)
May 21 Javascript
BootStrap入门学习第一篇
Aug 28 Javascript
three.js 实现露珠滴落动画效果的示例代码
Mar 01 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中使用cURL实现Get和Post请求的方法
2013/03/13 PHP
php+html5实现无刷新图片上传教程
2016/01/22 PHP
PHP快速生成各种信息提示框的方法
2016/02/03 PHP
thinkPHP+ajax实现统计页面pv浏览量的方法
2017/03/15 PHP
实例分析基于PHP微信网页获取用户信息
2017/11/24 PHP
PHP笛卡尔积实现算法示例
2018/07/30 PHP
设定php简写功能的方法
2019/11/28 PHP
javascript 获取表单file全路径
2009/12/31 Javascript
JavaScript Event学习第五章 高级事件注册模型
2010/02/07 Javascript
javascript 事件处理、鼠标拖动效果实现方法详解
2012/05/11 Javascript
通过JS自动隐藏手机浏览器的地址栏实现原理与代码
2013/01/02 Javascript
jQuery extend 的简单实例
2013/09/18 Javascript
createTextRange()的使用示例含文本框选中部分文字内容
2014/02/24 Javascript
javascript文本框内输入文字倒计数的方法
2015/02/24 Javascript
JavaScript实现选择框按比例拖拉缩放的方法
2015/08/04 Javascript
纯JS代码实现一键分享功能
2016/04/20 Javascript
浅析$(function) ready和onload 的区别
2016/09/03 Javascript
浅谈js中startsWith 函数不能在任何浏览器兼容的问题
2017/03/01 Javascript
原生js实现仿window10系统日历效果的实例
2017/10/31 Javascript
深入探讨JavaScript的最基本部分之执行上下文
2019/02/12 Javascript
详解vue项目中实现图片裁剪功能
2019/06/07 Javascript
vue.js基于v-for实现批量渲染 Json数组对象列表数据示例
2019/08/03 Javascript
[58:46]OG vs NAVI 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
[05:23]DOTA2-DPC中国联赛2月1日Recap集锦
2021/03/11 DOTA
Python Tkinter GUI编程入门介绍
2015/03/10 Python
在Python中处理字符串之isdecimal()方法的使用
2015/05/20 Python
Python基于pygame实现的font游戏字体(附源码)
2015/11/11 Python
对python append 与浅拷贝的实例讲解
2018/05/04 Python
Python处理中文标点符号大集合
2018/05/14 Python
详解Python with/as使用说明
2018/12/13 Python
如何利用Python 进行边缘检测
2020/10/14 Python
销售内勤岗位职责
2014/04/15 职场文书
小学生寒假家长评语
2014/04/16 职场文书
镇副书记专题民主生活会对照检查材料思想汇报
2014/10/02 职场文书
MySQL获取所有分类的前N条记录
2021/05/07 MySQL
微信小程序实现拍照和相册选取图片
2021/05/09 Javascript