关于this指向

this 的值不是在函数定义时确定的,而是在函数被调用时绑定的,它的指向完全取决于函数的调用方式。

1. 默认绑定

独立函数调用 (无法应用其他规则时)时,this 指向全局对象 (在浏览器中是 window,在 Node.js 中是 global)。在严格模式 ('use strict') 下,thisundefined

scss 复制代码
function showThis() {
  console.log(this);
}

showThis(); // 浏览器中输出: Window {...} (非严格模式)
            // 严格模式下输出: undefined

var a = 1;
function foo() {
  console.log(this.a);
}
foo(); // 输出: 1 (因为 this 指向 window,window.a = 1)

2. 隐式绑定

当函数作为一个对象的方法 被调用时,this 指向调用这个方法的那个对象

javascript 复制代码
const person = {
  name: 'Alice',
  greet: function() {
    console.log(`Hello, my name is ${this.name}`);
  }
};

person.greet(); // 输出: "Hello, my name is Alice"
                // 因为 greet 是 person 的方法,所以 this 指向 person

隐式丢失 :这是一个常见的坑。当方法被赋值给另一个变量或作为回调函数传递时,会丢失原来的 this 绑定,退回到默认绑定规则。

scss 复制代码
const greetFunc = person.greet; // 将方法赋值给一个变量
greetFunc(); // 输出: "Hello, my name is " (name 是 undefined)
             // 此时是独立函数调用,this 指向全局(或 undefined)

// 作为回调函数
setTimeout(person.greet, 100); // this 同样丢失!

3. 显式绑定

也就是使用call、aplly、bind显示指定this的指向。

4.new 绑定

使用 new 关键字调用函数(构造函数)时,this 会绑定到新创建的那个实例对象上。

javascript 复制代码
function Person(name) {
  // this = {}; (JS引擎隐式完成)
  this.name = name;
  this.sayHello = function() {
    console.log(`Hello from ${this.name}`);
  };
  // return this; (JS引擎隐式完成)
}

const alice = new Person('Alice');
alice.sayHello(); // 输出: "Hello from Alice"
// this 指向新创建的 alice 实例

5.箭头函数

ES6 的箭头函数是上述规则的例外 。它没有自己的 this ,它的 this继承自它定义时所处的外层(函数或全局)作用域this。这意味着箭头函数内的 this固定的,不会被调用方式改变。

javascript 复制代码
const obj = {
  value: 42,
  regularFunc: function() {
    console.log('Regular:', this.value); // this 指向 obj
  },
  arrowFunc: () => {
    console.log('Arrow:', this.value); // this 继承自外部,可能是 window 或 undefined
  }
};

obj.regularFunc(); // 输出: "Regular: 42"
obj.arrowFunc();   // 输出: "Arrow: undefined" (假设外层是全局作用域,如果是在浏览器环境,且定义有value变量 var value = 1,则此处会输出 Arrow: 1)

// 箭头函数解决回调中 this 丢失的问题
const otherObj = {
  value: 'Hi',
  init: function() {
    // 箭头函数这里的 this 继承自 init 函数,而 init 的 this 由隐式绑定指向 otherObj
    setTimeout(() => {
      console.log(this.value); // 输出: "Hi"
    }, 100);
  }
};
otherObj.init();
相关推荐
极客密码3 小时前
感谢雷总!Mimo大模型价值¥659/月的 MAX 套餐,让我免费领到了!
前端·ai编程·claude
深念Y4 小时前
我明白为什么B站没法在浏览器开直播了——Windows Chrome推流踩坑全记录
前端·chrome·webrtc·浏览器·srs·直播·flv
zhangxingchao4 小时前
AI应用开发七:可以替代 RAG 的技术
前端·人工智能·后端
Sun@happy5 小时前
现代 Web 前端渗透——基础篇(1)
前端·web安全
希冀1235 小时前
【CSS学习第十一篇】
前端·css·学习
隔窗听雨眠5 小时前
doctype、charset、meta如何控制整个渲染流水线
java·服务器·前端
kyriewen5 小时前
写组件文档写到吐?我用AI自动生成Storybook,同事以后直接抄
前端·javascript·面试
excel5 小时前
🧠 Prisma 表名大写 vs SQL 导出小写问题深度解析(附踩坑与解决方案)
前端·后端
周淳APP6 小时前
【前端工程化原理通识:从源头到运行时的理论阐述】
前端·编译·打包·前端工程化
五点六六六6 小时前
你敢信这是非Native页面写出来的渐变效果吗🌝(底层原理解析
前端·javascript·面试