首页 > 移动平台 > 详细

JS:apply、call、bind的区别

时间:2019-12-21 18:17:38      阅读:78      评论:0      收藏:0      [点我收藏+]

首先,它们是什么呢?我们先看call跟apply:

Function.prototype的方法有apply跟call,所以每个函数都包含call、apply属性。

共同点:都可以改变this的指向

差异:接收函数参数的方式不同

技术分享图片

call: 第一个值是让t函数addEvent的this指向为obj对象,随后都是携带的addEvent函数的实参,需要逐个列出来

apply: 第一个值同上, 但是addEvent的实参通通都放在了一个数组中

那bind呢?它的作用也是改变this的指向,不过bind后还是函数,需要再进行调用;

技术分享图片

===============================================

apply的妙用:

应用场景:

1、让 Math.max()方法可以挑出一个数组的最大值

技术分享图片

2、合并两个数组(会改变原来的数组哦)

技术分享图片

JS:apply、call、bind的区别

原文:https://www.cnblogs.com/hxw1024/p/12077636.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!