当前位置: 首页 > 知识库问答 >
问题:

使用call、apply、bind的箭头函数-不工作?[副本]

南门刚捷
2023-03-14
var obj = {num: 2}

var addToThis = function (a, b, c) {
  return this.num + a + b + c
}

// call
console.log(addToThis.call(obj, 1, 2, 3))

// apply
const arr = [1, 2, 3]
console.log(addToThis.apply(obj, arr))

// bind
const bound = addToThis.bind(obj)
console.log(bound(1, 2, 3))
const obj = {num: 2}

const addToThis = (a, b, c) => {
  return this.num + a + b + c
}

它不再工作,并抛出一个错误:无法读取未定义的属性'num'。

有人能解释一下为什么this不再起作用了吗?

共有1个答案

斜单鹗
2023-03-14

Lambda函数(箭头函数)不创建新的函数上下文和使用调用函数的上下文。

所以“this”指的是父上下文。如果没有'num'变量,则为未定义

通常这真的很方便,因为大多数时候您使用一个上下文,而不是在您创建的每个函数中创建一个新的上下文。在我看来,call/apply/bind是完全混乱的,而lambda函数使它变得不必要。

 类似资料:
  • 本文向大家介绍javascript中call,apply,bind函数用法示例,包括了javascript中call,apply,bind函数用法示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了javascript中call,apply,bind函数用法。分享给大家供大家参考,具体如下: 一.call函数 a.call(b); 简单的理解:把a对象的方法应用到b对象上(a里如果有thi

  • 本文向大家介绍bind,apply,call的区别?相关面试题,主要包含被问及bind,apply,call的区别?时的应答技巧和注意事项,需要的朋友参考一下 参考回答: apply:调用一个对象的一个方法,用另一个对象替换当前对象。例如:B.apply(A, arguments);即A对象应用B对象的方法。 call:调用一个对象的一个方法,用另一个对象替换当前对象。例如:B.call(A, a

  • call()和apply() 介绍 这两个方法都是函数对象的方法,需要通过函数对象来调用。 当函数调用call()和apply()时,函数都会立即执行。 都可以用来改变函数的this对象的指向。 第一个参数都是this要指向的对象(函数执行时,this将指向这个对象),后续参数用来传实参。 显式绑定this JS提供的绝大多数函数以及我们自己创建的所有函数,都可以使用call 和apply方法。

  • 问题内容: 我已经知道了,并且是类似的函数集(函数的上下文)。 区别在于我们发送参数的方式(手动vs数组) 题: 但是什么时候应该使用该 方法? 问题答案: 当你希望稍后在特定上下文中调用该函数时使用,该事件在事件中很有用。当你想立即调用该函数并修改上下文时,请使用或。 调用/应用立即调用该函数,而bind返回一个函数,该函数在以后执行时将具有用于调用原始函数的正确上下文集。这样,你可以在异步回调

  • 本文向大家介绍javascript中apply、call和bind的使用区别,包括了javascript中apply、call和bind的使用区别的使用技巧和注意事项,需要的朋友参考一下 在JS中,这三者都是用来改变函数的this对象的指向的,他们有什么样的区别呢。 在说区别之前还是先总结一下三者的相似之处: 1、都是用来改变函数的this对象的指向的。 2、第一个参数都是this要指向的对象。

  • 本文向大家介绍浅谈javascript中的call、apply、bind,包括了浅谈javascript中的call、apply、bind的使用技巧和注意事项,需要的朋友参考一下 在JavaScript中,call、apply和bind 是Function对象自带的三个方法,这三个方法的主要作用是改变函数中的this指向,从而可以达到`接花移木`的效果。本文将对这三个方法进行详细的讲解,并列出几个