javascript中apply/call和bind的使用


Posted in Javascript onFebruary 15, 2017

fun.apply(context,[argsArray])

立即调用fun,同时将fun函数原来的this指向传入的新context对象,实现同一个方法在不同对象上重复使用。

context:传入的对象,替代fun函数原来的this;

argsArray:一个数组或者类数组对象,其中的数组参数会被展开作为单独的实参传给 fun 函数,需要注意参数的顺序。

fun.call(context,[arg1],[arg2],[…])

同apply,只是参数列表不同,call的参数需要分开一个一个传入。如果不知道参数个数,则使用apply。

使用:

Math.max()只接收单独的参数,通过下面的方法可以在数组上面使用max方法:

Math.max.apply(null, array);//会将array数组参数展开成单独的参数再传入
Array.prototype.push.apply(arr1,arr2);//将一个数组拆开push到另一个数组中;不用apply则会将后续数组参数当成一个元素push进去。
Array.prototype.slice.call(arguments);//在类素组对象上使用slice方法

fun.bind(context,[arg1],[arg2],[…])

使fun方法执行的context永不变。

arg1:要传递到新函数的参数列表

返回一个函数供后续调用,其函数体和原函数fun一样,但新函数的this指向新传入的context对象。新函数具有指定的初始参数,后续调用时的实参要往后面排。

var displayArgs = function (val1, val2, val3, val4) {
 console.log(val1 + " " + val2 + " " + val3 + " " + val4);
}
var emptyObject = {};
// 生成新函数时指定了2个参数
var displayArgs2 = displayArgs.bind(emptyObject, 12, "a");
// 调用时传入另2个参数,往后排
displayArgs2("b", "c");
// Output: 12 a b c

使用bind()方法改写slice()方法:

var _Slice = Array.prototype.slice;
var slice = Function.prototype.call.bind(_Slice);
slice(…);

bind()兼容Ie5~ie8处理

if (!Function.prototype.bind) {
 Function.prototype.bind = function(context) {
  var self = this, // 即调用bind方法的目标函数
  args = arguments;
  return function() {
   self.apply(context, Array.prototype.slice.call(args, 1));
  }
 }
}

一般情况下setTimeout()的this指向window或global对象。当使用类的方法时需要this指向类实例,就可以使用bind()将this绑定到调用对象。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
js实现可拖动DIV的方法
Dec 17 Javascript
详细讲解JavaScript中的this绑定
Oct 10 Javascript
浅谈js函数三种定义方式 & 四种调用方式 & 调用顺序
Feb 19 Javascript
javascript 动态生成css代码的两种方法
Mar 17 Javascript
微信小程序实现文字跑马灯效果
May 26 Javascript
使用D3.js+Vue实现一个简单的柱形图
Aug 05 Javascript
Vue常用的几个指令附完整案例
Nov 06 Javascript
怎样使你的 JavaScript 代码简单易读(推荐)
Apr 16 Javascript
tsconfig.json配置详解
May 17 Javascript
Vue中全局变量的定义和使用
Jun 05 Javascript
JS 设计模式之:工厂模式定义与实现方法浅析
May 06 Javascript
利用 JavaScript 构建命令行应用
Nov 17 Javascript
JS实现图片放大缩小的方法
Feb 15 #Javascript
JavaScript中的编码和解码函数
Feb 15 #Javascript
js date 格式化
Feb 15 #Javascript
JS实现最简单的冒泡排序算法
Feb 15 #Javascript
javascript设计模式之单体模式学习笔记
Feb 15 #Javascript
JavaScript中的toString()和toLocaleString()方法的区别
Feb 15 #Javascript
javascript设计模式之模块模式学习笔记
Feb 15 #Javascript
You might like
php中目录,文件操作详谈
2007/03/19 PHP
CI框架源码阅读,系统常量文件constants.php的配置
2013/02/28 PHP
PHP实现的博客欢迎提示功能(很特别哦)
2014/06/05 PHP
THINKPHP2.0到3.0有哪些改进之处
2015/01/04 PHP
php处理带有中文URL的方法
2016/07/11 PHP
php 根据URL下载远程图片、压缩包、pdf等文件到本地
2019/07/26 PHP
JS无法捕获滚动条上的mouse up事件的原因猜想
2012/03/21 Javascript
JavaScript之Getters和Setters 平台支持等详细介绍
2012/12/07 Javascript
JavaScript编写Chrome扩展实现与浏览器的交互及时间通知
2016/05/16 Javascript
ion content 滚动到底部会遮住一部分视图的快速解决方法
2016/09/06 Javascript
nodejs Assert中equal(),strictEqual(),deepEqual(),strictDeepEqual()比较
2017/09/18 NodeJs
Vue精简版风格指南(推荐)
2018/01/30 Javascript
解决Vue2.x父组件与子组件之间的双向绑定问题
2018/03/06 Javascript
Vue中使用 setTimeout() setInterval()函数的问题
2018/09/13 Javascript
JavaScript数组特性与实践应用深入详解
2018/12/30 Javascript
详解JavaScript 的执行机制
2020/09/18 Javascript
ant design 日期格式化的实现
2020/10/27 Javascript
[01:20]PWL S2开团时刻第三期——团战可以输 蝙蝠必须死
2020/11/26 DOTA
Python 3中的yield from语法详解
2017/01/18 Python
用十张图详解TensorFlow数据读取机制(附代码)
2018/02/06 Python
pyqt5对用qt designer设计的窗体实现弹出子窗口的示例
2019/06/19 Python
手把手教你Python yLab的绘制折线图的画法
2019/10/23 Python
Django集成celery发送异步邮件实例
2019/12/17 Python
django 模型中的计算字段实例
2020/05/19 Python
Python打印不合法的文件名
2020/07/31 Python
Python3 pyecharts生成Html文件柱状图及折线图代码实例
2020/09/29 Python
html5标记文字_动力节点Java学院整理
2017/07/11 HTML / CSS
我们是伦敦女孩:WalG
2018/01/08 全球购物
澳洲女装时尚在线:Blue Bungalow
2018/05/05 全球购物
十一酒店活动方案
2014/02/20 职场文书
常务副总经理岗位职责
2014/04/12 职场文书
小学生九一八纪念日83周年演讲稿500字
2014/09/17 职场文书
销售会议开幕词
2015/01/28 职场文书
利用Nginx代理如何解决前端跨域问题详析
2021/04/02 Servers
python实战之用emoji表情生成文字
2021/05/08 Python
索尼ICF-5900W收音机测评
2022/04/24 无线电