JS中this的几种情况

Posted 1800000000nm

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS中this的几种情况相关的知识,希望对你有一定的参考价值。

1.给元素的某个事件行为绑定方法,事件触发,方法执行,此时方法中的this一般都是当前元素本身:

<div id="div"></div>
div.onclick = function() {
    console.log(this); //=><div id="div"></div>
};
div.addEventListener(‘click‘, function () {
    console.log(this);  //=><div id="div"></div>
}, false);

这里边有个特殊情况就是DOM2级绑定事件

div.attachEvent(‘onclick‘,function anonymous(){
    console.log(this); //=>window
});

 

2.普通函数执行,它里边的this是谁,取决于方法执行前面是否有“.”,有的话,“.”前面是谁this就是谁,没有的话并且是在非严格模式下this就是window,严格模式下是undefined:

function fn() {
    console.log(this);
}
let obj = {
    name: ‘OBJ‘,
    fn: fn
}; 
fn(); //window
obj.fn(); //{name: ‘OBJ‘,fn: fn}

 

3.构造函数执行(也即是new执行),函数中的this是当前类的实例:

function F() {
    console.log(this);
}
let f = new F; // F {}

 

4.箭头函数中没有this,所用到的this都是其上下文中的this(或者说是上级上下文):

let obj = {
    fn: () => {
        console.log(this);            
    }
}
obj.fn(); //window
let obj = {
    fn: function () {
        setTimeout(_ => {
            console.log(this);    
        }, 1000);
    }
};
obj.fn(); //obj

 

5.基于call/apply/bind可以改变函数中this的指向:

let obj = {
    fn: function(){
        console.log(this);
        }
}
obj.fn(); //obj
obj.fn.call(12); //12

 

以上是关于JS中this的几种情况的主要内容,如果未能解决你的问题,请参考以下文章

a标签调用js的几种方法

JS 创建对象(常见的几种方法)

js的构造函数继承的几种类型

Laravel:如何在控制器的几种方法中重用代码片段

js确保正确this的几种写法

a标签调用js的几种方法