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

相关推荐
阿维的博客日记16 分钟前
div和span区别
前端·javascript·html
伍哥的传说20 分钟前
Vue3 Anime.js超级炫酷的网页动画库详解
开发语言·前端·javascript·vue.js·vue·ecmascript·vue3
欢乐小v42 分钟前
elementui-admin构建
前端·javascript·elementui
霸道流氓气质1 小时前
Vue中使用vue-3d-model实现加载3D模型预览展示
前端·javascript·vue.js
晨岳2 小时前
web开发-CSS/JS
前端·javascript·css
冲!!2 小时前
前端获取当前日期并格式化(JS)
开发语言·前端·javascript
雲墨款哥2 小时前
算法练习-Day1-交替合并字符串
javascript·算法
福娃B2 小时前
【React】React初体验--手把手教你写一个自己的React初始项目
前端·javascript·react.js
油丶酸萝卜别吃3 小时前
怎么判断一个对象是不是vue的实例
前端·javascript·vue.js
Mintopia4 小时前
Three.js 滚动条 3D 视差动画原理解析
前端·javascript·three.js