2024前端面经---改变this指向问题(call、apply、bind)_apply改变this
发布日期:2025-06-20 09:34:37 浏览次数:6 分类:精选文章

本文共 1708 字,大约阅读时间需要 5 分钟。

this指向改变方法详解

一、this指向基础知识

this是一个关键字,其指向取决于函数的类型和调用方式。在 JavaScript 中,this的默认指向是 window对象。以下是两种主要函数类型对this的影响:

  • 普通函数

    this 的指向取决于谁调用了函数。如果没有明确调用者,this 默认指向 window

  • 箭头函数(ES6)

    • 如果箭头函数嵌套在另一个函数中,this 指向外层函数的上下文。
    • 如果箭头函数没有外层函数包裹,this 默认指向 window
  • 以下是实际场景中的 this 指向表现:

    • 场景一

      直接在控制台打印 this,结果是 window

    • 场景二

      使用 setTimeout 定时器执行回调函数,回调函数中的 this 仍然指向 window

    • 场景三

      事件处理中绑定的 this 指向目标DOM元素。

    • 场景四

      对象方法中的 this 指向调用者对象。

    • 场景五

      箭头函数在对象字面量中使用时,this 指向 window,因为无法继承对象的上下文。

    二、改变this指向的三种方法

  • call() 方法

    • 通过 call() 方法可以指定 this 的指向。
    • 传入的第一个参数会被赋值给 this
    • 例如:
      let obj1 = { name: 'james', getName1: function(a, b, c) { ... } };obj1.getName1.call(obj2, 1, 2, 3);
    • 这时 this 会指向 obj2
  • apply() 方法

    • call() 类似,但主要用于传递多个参数。
    • 例如:
      let obj1 = { name: 'james', getName1: function(a, b, c) { ... } };obj1.getName1.apply(obj2, [1, 2, 3]);
    • 这时 this 会指向 obj2,并将参数 1, 2, 3 传递给函数。
  • bind() 方法

    • 用于长期绑定 this 的指向,返回一个新的函数。
    • 例如:
      let boundFunc = obj1.getName1.bind(obj2);boundFunc(1, 2, 3);
    • 这时 this 始终指向 obj2
  • 三、实战演练

    示例一:使用 call() 改变 this 指向

    let obj1 = { name: 'james', getName1: function(a, b, c) { console.log(`getName ${this.name}`); } };let obj2 = { name: 'davis' };obj1.getName1.call(obj2, 1, 2, 3);

    执行后,getName 会输出 davis,并显示参数 1, 2, 3。

    示例二:使用 apply() 改变 this 指向

    let obj1 = { name: 'james', getName1: function(a, b, c) { console.log(`getName ${this.name}`); } };let obj2 = { name: 'davis' };obj1.getName1.apply(obj2, [1, 2, 3]);

    执行后,结果与 call() 相同。

    示例三:使用 bind() 绑定 this

    let obj1 = { name: 'james', getName1: function(a, b, c) { console.log(`getName ${this.name}`); } };let obj2 = { name: 'davis' };let boundFunc = obj1.getName1.bind(obj2);boundFunc(1, 2, 3);

    执行后,getName 会始终输出 davis

    四、总结

    通过 call()apply()bind() 三种方法,可以精确控制 this 的指向。掌握这些方法是 JavaScript 开发的核心技能之一。

    上一篇:2024前端面经---改变this指向问题(call、apply、bind)_apply改变this
    下一篇:2024-JAVA-大数据-面试汇总_大数据java部门面试

    发表评论

    最新留言

    做的很好,不错不错
    [***.243.131.199]2026年05月26日 12时26分40秒