web前端面试-- 在 JavaScript 中 bind , apply 和 call 的区别

本人是一个web前端开发工程师,主要是vue框架,整理了一些面试题,今后也会一直更新,有好题目的同学欢迎评论区分享 ;-)

web面试题专栏:点击此处


在 JavaScript 中, bind , apply 和 call 都是用于改变函数执行上下文的方法。它们的区别如下:

  1. bind 方法创建一个新函数,新函数的执行上下文被绑定到指定的对象。它不会立即执行函数,而是返回一个绑定了执行上下文的函数,可以稍后调用。 调用的时候传递单独的参数~
const obj = { name: 'Penk' };
function greet(str) {
  console.log(`Hello, ${this.name+str} !`);
}
const boundGreet = greet.bind(obj,'是个码农');
boundGreet(); // 输出:Hello, Penk是个码农!
  1. apply 方法调用函数,并将一个指定的对象作为执行上下文,以及**一个数组(或类数组对象)**作为参数传递给函数。数组中的每个元素将作为参数传递给函数。
const obj = { name: 'Penk' };
function greet(greeting) {
  console.log(`${greeting}, ${this.name}!`);
}
greet.apply(obj, ['Hi']); // 输出:Hi, Penk!
  1. call 方法调用函数,并将一个指定的对象作为执行上下文,以及单独的参数传递给函数。每个参数将作为单独的参数传递给函数。
const obj = { name: 'Penk' };
function greet(greeting) {
  console.log(`${greeting}, ${this.name}!`);
}
greet.call(obj, 'Hey'); // 输出:Hey, Penk!

总结:

  • bind 创建一个新函数,并绑定执行上下文,调用的时候传递单独的参数。
  • apply 调用函数,并传递一个数组作为参数。
  • call 调用函数,并传递单独的参数。

这些方法允许您在 JavaScript 中更灵活地控制函数的执行上下文。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Penk是个码农

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值