Javascript函数里的this指向

this的指向基于函数执行环境动态绑定

  1. 函数作为对象的方法,函数里的this指向对象
js 复制代码
var a=3;
var obj ={  
  a:1;   
  getA:function(){alert(this.a);
}
obj.getA(); // 输出 1
  1. 函数作为普通函数调用,函数里的this总是指向window
js 复制代码
var name ='globalname';
var myObject ={      
  name:'thisname',      
  getName:function(){return this.name;}    
};
var getName =myObject.getName;
console.log(getName());//输出globalname,当赋值后直接调用getName相当于普通函数调用
js 复制代码
// html
<div id='div1'>我是div1</div>
// js
var  id ='globalid';
document.getElementById('div1').onclick =function(){
alert(this.id);
var callback = function(){ alert(this.id)};}; 
callback();
}
//div1 globalid
  1. 作为构造器调用当用new运算符调用函数时,该函数总会返回一个对象,通常情况下,构造器里的this就指向返回的这个对象
js 复制代码
var MyClass = function(){  this.name = 'sven';}
var obj = new MyClass();
alert ( obj.name ); // 输出:sven 

如果构造器显式地返回了一个object类型的对象,那么此次运算结果最终会返回这个对象,而不是我们之前期待的this

js 复制代码
var MyClass = function(){  this.name = 'sven';  return {name:'anne'};  }
var obj = new MyClass(); 
alert ( obj.name ); // 输出:anne

如果构造器不显式地返回任何数据,或者是返回一个非对象类型的数据,就不会造成上述问题

js 复制代码
var MyClass = function(){  this.name = 'sven';  return 'anne';  }
var obj = new MyClass(); 
alert ( obj.name ); // 输出:sven
  1. 箭头函数的作用域

箭头函数在哪里定义就指向哪里。箭头函数没有自己的 this,会捕获定义时的外层 this(词法绑定)。

js 复制代码
const obj2 = {  
  name: 'Tom', 
  greet: () => console.log(this.name)
};
obj2.greet(); // undefined(因为 this 来自全局)

更改this的指向

主要通过call,apply,bind来更改函数中this的指向

相关推荐
Cobyte18 分钟前
4.响应式系统基础:从发布订阅模式的角度理解 Vue3 的数据响应式原理
前端·javascript·vue.js
晓得迷路了21 分钟前
栗子前端技术周刊第 124 期 - ESLint v10.2.0、React Native 0.85、Node.js 25.9.0...
前端·javascript·eslint
星空椰29 分钟前
JavaScript基础:运算符和流程控制
开发语言·javascript·ecmascript
窝子面1 小时前
NestJs+MongoDB+Deepseek+Langchain实现ai聊天助手
javascript·数据库·人工智能·mongodb
吴声子夜歌1 小时前
ES6——Calss详解
javascript·es6·原型模式
❆VE❆1 小时前
虚拟列表原理与实战运用场景详解
前端·javascript·css·vue.js·html·虚拟列表
灵感__idea9 小时前
Hello 算法:贪心的世界
前端·javascript·算法
killerbasd12 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
橘子编程13 小时前
JavaScript与TypeScript终极指南
javascript·ubuntu·typescript
叫我一声阿雷吧13 小时前
JS 入门通关手册(45):浏览器渲染原理与重绘重排(性能优化核心,面试必考
javascript·前端面试·前端性能优化·浏览器渲染·浏览器渲染原理,重排重绘·reflow·repaint