一分钟搞懂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对象最优先,箭头继承看外层!

相关推荐
kyriewen9 小时前
代码写成一锅粥?3个设计模式让你的项目“起死回生”
前端·javascript·设计模式
不会敲代码19 小时前
从零搭建 AI 日记助手:用 Milvus 向量数据库实现语义搜索
javascript·openai
threelab10 小时前
Three.js UV 图像变换效果 | 三维可视化 / AI 提示词
javascript·人工智能·uv
竹林81812 小时前
用Viem替代ethers.js:从一次签名失败到完整迁移的实战记录
前端·javascript
不可能的是13 小时前
Claude Code 子 Agent 机制全解:怎么跑起来、怎么被管理、怎么互不干扰
javascript
HSunR14 小时前
dify 搭建ai作业批改流
开发语言·前端·javascript
代码不加糖14 小时前
2026 跨境电商独立站实战:从 0 到 1 搭建高转化 SaaS 商城(附源码)
开发语言·前端·javascript
用户6175171570116 小时前
关于普通函数和箭头函数的this
javascript
RPGMZ16 小时前
RPGMakerMZ 地图存档点制作 标题继续游戏直接读取存档
开发语言·javascript·游戏·游戏引擎·rpgmz·rpgmakermz
有一个好名字17 小时前
Agent Loop —— 一切从那个 while 循环开始
前端·javascript·chrome