this指向问题(箭头函数没有this)
2024-08-30 15:17:51
全局环境下,指向windows
console.log(this.document === document); // true
函数上下文调用
function f1(){
return this;
}
f1() === window; // true对象中的this
对象内部方法的this指向调用这些方法的对
象,函数的定义位置不影响其this指向,
1. this指向只和调用函数的对象有关。
2. 多层嵌套的对象,内部方法的this指向离被调用
函数最近的对象(window也是对象,其内部对象调
用方法的this指向内部对象, 而非window)。
构造函数中this
构造函数中的this与被创建的新对象绑定。DOM事件处理函数
(1)当函数被当做监听事件处理函数时, 其 this 指向触发该事件的元素 (针对于addEventListener事件)
(2)代码被内联处理函数调用时,它的this指向监听器所在的DOM元素,当代码被包括在函数内部执行时,其this指向等同于 *函数直接调用*的情况setTimeout & setInterval
对于延时函数内部的回调函数的this指向全局对象window
箭头函数中的 this
(1)由于箭头函数不绑定this, 它会捕获其所在(即定义的位置)上下文的this值, 作为自己的this值,
function Person() {
this.age = 0;
setInterval(() => {
this.age++;
}, 3000);
}
Var p = new Person();
(2)方法的箭头函数this指向全局window对象,而普通函数则指向调用它的对象,箭头函数没有thisvar obj = {
I: 10,
b: () => console.log(this.i, this),
c: function() {
console.log( this.i, this)
}
}
obj.b(); // undefined window{...}
obj.c(); // 10 Object {...}
最新文章
- OpenCV图像Canny边缘检测
- 如何将maven项目导入myeclipse中
- 设计模式之单实例模式(Singleton)
- ADODB.Connection 错误 '800a0e7a' 未找到提供程序 该程序可能未正确安装
- 深入浅出理解iOS经常使用的正則表達式—基础篇[Foundation]
- ZendFramework2 源码分析 init_autoloader.php
- Caused by: android.util.AndroidRuntimeException: Calling startActivity() from outside of an Activity
- Swift - 点击输入框外部屏幕关闭虚拟键盘
- 玩转html5(二)----用canvas结合脚本在画布上画简单的图(html5又一强大功能)
- Fiddler 教程 转自小坦克
- Java内存使用量测试
- sqlserver使用job删除过期备份文件
- php : 文件及文件夹操作(创建、删除、移动、复制)
- 【Python游戏编程03--pygame事件与设备轮询】
- 对于两个初始时设置为Sensor的刚体,不会触发preSolve和postSolve
- 【learning】 扩展lucas定理
- tomcat 管理端 安全措施
- 使用R语言和XML包抓取网页数据-Scraping data from web pages in R with XML package
- 基于cookie或session的登陆验证之安全性问题
- POJ1220 Number Base Conversion