javascript中apply/call和bind的使用

前端之家收集整理的这篇文章主要介绍了javascript中apply/call和bind的使用前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

@H_4030@

fun.apply(context,[argsArray])


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


@H_403_0@

context:

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


@H_403_0@

argsArray:

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


@H_4030@

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


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


@H
4030@

使用:


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


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

@H_403_0@

fun.bind(context,[…])

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

@H_403_0@

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

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

生成新函数时指定了2个参数 var displayArgs2 = displayArgs.bind(emptyObject,12,"a"); // 调用时传入另2个参数,往后排 displayArgs2("b","c"); // Output: 12 a b c
@H_403_0@使用bind()方法改写slice()方法

@H_403_0@bind()兼容Ie5~ie8处理

调用bind方法的目标函数 args = arguments; return function() { self.apply(context,Array.prototype.slice.call(args,1)); } } }
@H_403_0@一般情况下setTimeout()的this指向window或global对象。当使用类的方法时需要this指向类实例,就可以使用bind()将this绑定到调用对象。

@H_403_0@以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持编程之家!

原文链接:https://www.f2er.com/js/41642.html

猜你在找的JavaScript相关文章