一分钟搞懂this指向

独立函数调用------默认绑定!this指向全局对象(浏览器中就是Window)

scss 复制代码
function fire() {
  console.log(this); // 浏览器中: Window
}
fire(); // 函数直接调用

通过对象调用------隐式绑定!this指向调用它的对象

javascript 复制代码
const weapon = {
  name: "AK47",
  shoot() {
    console.log(this.name); // AK47
  }
};
weapon.shoot(); // 通过对象调用

call/apply/bind------显式绑定!强行指定this指向

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

const gun = { bullet: 30 };
reload.call(gun);   // 30
reload.apply(gun);  // 30
const bindReload = reload.bind(gun);
bindReload();       // 30

new实例化------构造函数模式!this指向新创建的对象

javascript 复制代码
function Sniper(name) {
  this.name = name; // this指向新对象
}
const awp = new Sniper("AWM"); 
console.log(awp.name); // AWM

箭头函数是例外!没有自己的this,继承外层上下文

js复制代码

javascript 复制代码
const obj = {
  timer: function() {
    setTimeout(() => {
      console.log(this); // obj(继承外层this)
    }, 100);
  }
};
obj.timer();

记住口诀:谁调用指向谁,new对象最优先,箭头继承看外层!

相关推荐
coderHing[专注前端]2 小时前
告别 try/catch 地狱:用三元组重新定义 JavaScript 错误处理
开发语言·前端·javascript·react.js·前端框架·ecmascript
UIUV2 小时前
JavaScript中this指向机制与异步回调解决方案详解
前端·javascript·代码规范
momo1002 小时前
IndexedDB 实战:封装一个通用工具类,搞定所有本地存储需求
前端·javascript
San302 小时前
从零到一:彻底搞定面试高频算法——“列表转树”与“爬楼梯”全解析
javascript·算法·面试
JellyDDD2 小时前
h5上传大文件可能会导致手机浏览器卡死,重新刷新的问题
javascript·上传文件
T___T3 小时前
一个定时器,理清 JavaScript 里的 this
前端·javascript·面试
San303 小时前
深度驱动:React Hooks 核心之 `useState` 与 `useEffect` 实战详解
javascript·react.js·响应式编程
flashlight_hi3 小时前
LeetCode 分类刷题:199. 二叉树的右视图
javascript·算法·leetcode
刘一说4 小时前
Vue Router:官方路由解决方案解析
前端·javascript·vue.js