当前位置: 首页 > 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/news/309365.html

相关文章:

  • 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状态机
  • I2C/IIC学习笔记
  • nonlocal本质讲解(前篇)——从滤波到Nonlocal均值滤波
  • Java项目实战II基于Spring Boot的宠物商城网站设计与实现
  • linux-软件包管理-包管理工具(Debian 系)
  • 【C++入门学习】7. 类型
  • Java项目实战II基于Java+Spring Boot+MySQL的服装厂服装生产管理系统的设计与实现
  • 归并排序
  • Text-to-SQL技术升级 - 阿里云OpenSearch-SQL在BIRD榜单夺冠方法
  • [ffmpeg]音频格式转换
  • matlab绘制不同区域不同色彩的图,并显示数据(代码)