当前位置: 首页 > article >正文

Js中call、apply和bind的区别

call、apply和bind三个方法都可以用来改变函数的this指向

call()

call( ) 是接收一个及其以上的参数,第一个参数表示this要指向的对象,其余参数表示调用函数需要传入的参数,返回调用函数的返回结果,属于立即执行函数

apply()

apply( ) 是接收两个参数,第一个参数表示this要指向的对象,第二参数表示调用函数需要传入的参数所组成的数组,返回调用函数的返回结果,属于立即执行函数

bind()

bind( ) 是接收一个及其以上的参数,和call()一致,但是其返回是一个函数,而不是调用函数的返回结果。

区别 

相同点

都是改变this的指向,传入的第一个参数都是绑定this的指向,在非严格模式中,如果第一个参数是null或者undefined,会把全局对象(浏览器是window)作为this的值,要注意的是,在严格模式中,null 就是 null,undefined 就是 undefined

不同点

call和apply唯一的区别

call传入的是参数列表,apply传入的是数组,也可以是类数组

bind和call、apply的区别

bind返回的是一个改变了this指向的函数,便于稍后调用,不像call和apply会立即调用;bind和call很像,传入的也是参数列表,但是可以多次传入,不需要像call,一次传入

当 bind 返回的函数 使用new作为构造函数时,绑定的 this 值会失效,this指向实例对象,但传入的参数依然生效 (new调用的优先级 > bind调用)

示例

// call 方法
function foo() {
    console.log(this.name)
}

const obj1 = { name: 'Alice' }
const obj2 = { name: 'Bob'}

foo.call(obj1)  // 输出:Alice
foo.call(obj2)  // 输出:Bob

// apply方法
function bar(greeting) {
    console.log(greeting + ',' + this.name)
}

bar.apply(obj1, ['Hello']) // 输出:Hello,Alice
bar.apply(obj2, ['Hi'])    // 输出:Hi,Bob

// bind方法
const baz = foo.bind(obj1)
baz()  // 输出:Alice

总结 

特性callapplybind
用法直接调用函数并指定 this 值直接调用函数并指定 this 值创建一个新函数并指定 this 值
参数传递方式逐个传递参数以数组形式传递参数预设参数(可选)
返回值返回函数调用的结果返回函数调用的结果返回一个新函数
适用场景当你知道参数个数时当参数以数组形式存在时当你需要一个函数的特定上下文时
是否立即调用
  • 三者都可以改变函数的this对象指向

  • 三者第一个参数都是this要指向的对象,如果没有这个参数或参数为undefined或null,则默认指向全局window

  • 三者都可以传参,但是apply是数组,而call是参数列表,且apply和call是一次性传入参数,而bind可以分为多次传入

  • bind是返回绑定之后的函数,apply和call是立即执行

本篇博客到此就结束了,希望各位大佬们点点关注点点赞,红豆泥阿里嘎多! 🌹


http://www.kler.cn/a/309365.html

相关文章:

  • 信捷 PLC C语言 POU 指示灯交替灭0.5秒亮0.5秒(保持型定时器)
  • 基于MATLAB+opencv人脸疲劳检测
  • redis实现消息队列的几种方式
  • 【考研数学:高数2】数列极限
  • 11.11比赛总结
  • AI大模型:重塑软件开发流程的优势、挑战及应对策略
  • C语言 | Leetcode C语言题解之第412题Fizz Buzz
  • 鸿蒙开发(NEXT/API 12)【网络连接管理】 网络篇
  • 实现浏览器的下拉加载功能(类似知乎)
  • maven项目下使用Jacoco测试覆盖率
  • vue3使用panolens.js实现全景,带有上一个下一个,全屏功能
  • 风力发电厂智能化转型5G工业路由器物联网应用解决方案
  • 大数据-133 - ClickHouse 基础概述 全面了解
  • C#基础(12)递归函数
  • 测试工程师学历路径:从功能测试到测试开发
  • MUNIK谈ASPICE系列专题分享(六)企业为什么要做ASPICE?
  • 5.内容创作的未来:ChatGPT如何辅助写作(5/10)
  • 计算机人工智能前沿进展-大语言模型方向-2024-09-15
  • Nacos服务治理
  • 电学基础概念详解及三相电公式汇总
  • AI写作神器:助力体制内小白轻松完成材料撰写,减少慌张茫然
  • unity的学习
  • linux驱动开发-内核并发 poll 和 lock
  • 深度解码:机器学习与深度学习的界限与交融
  • CMakeLists.txt的学习了解
  • 【LabVIEW学习篇 - 25】:JKI状态机