博客
关于我
2024前端面经---改变this指向问题(call、apply、bind)_apply改变this
阅读量:802 次
发布时间:2023-04-17

本文共 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 开发的核心技能之一。

    转载地址:http://yxgfk.baihongyu.com/

    你可能感兴趣的文章
    oracle中表和视图的区别,oracle中常用表和视图
    查看>>
    oracle之表空间(tablespace)、方案(schema)、段(segment)、区(extent)、块(block)
    查看>>
    Oracle从11g导出后导入10g
    查看>>
    oracle从备份归档日志的方法集中回收
    查看>>
    oracle优化器analyzed,Oracle 学习之 性能优化(十三) 索引
    查看>>
    Oracle修改字段类型
    查看>>
    Oracle修改表或者字段的注释
    查看>>
    oracle典型安装失败,安装oracle 10失败
    查看>>
    Oracle内存结构详解(四)--Oracle SGA其他组成部分
    查看>>
    Oracle函数与存储过程和程序包
    查看>>
    Oracle分析函数之LEAD和LAG
    查看>>
    Oracle分组取前n条记录
    查看>>
    Oracle分页sql
    查看>>
    Oracle创建database link(dblink)和同义词(synonym)
    查看>>
    oracle创建数据库的步骤
    查看>>
    Oracle创建用户、角色、授权、建表
    查看>>
    Oracle创建用户与授予表空间与权限
    查看>>
    oracle创建表(并且实现ID自增)
    查看>>
    oracle创建视图与生成唯一编号
    查看>>
    oracle删除重复数据保留第一条记录
    查看>>