文章目的是总结下这个事情,如果没有考虑周全,遗漏某一条,请过路的留言写,我在补上。

  1. 在自制行函数中,this --> window
    let obj = {
        name: 'fung',
        getName: ~function(params) {
            // this-->window
           console.log(this); //window
        }() 
    };
  1. 给元素的某个事件绑定方法,当事件触发执行,对应方法的时候,方法中的this一般是指当前操作的元素本身。
let box = document.getElementById('box');
box.onclick = function () {
    // this -- > box
    console.log('box', this); //box对象
}
  1. 当方法执行时,看方法的前面有没有点,如果有点,点前面是谁,this就是指向谁;如果没有点一般都是指向window
var objTest = {
    name: 'fung',
    getName: function () {
        console.log('objTest', this);
    },
    timeout: function(params) {
        setTimeout(function(){
            //this --> window
            console.log('setTimeout', this);
        }, 1000);
    }
};
objTest.getName(); //this --> objTest
let fn = objTest.getName;
fn(); // this --> window
  1. 在构造函数模式中,方法体中出现的this是当前类的一个实例。
function Person(name, age, sex) {
    //this --> person(Person类的实例person)
    this.name = name;
    this.age = age;
    this.sex = sex;
    console.log('Person', this);
}
let person = new Person('fung', 19, 'femail');
  1. 在setTimeout函数中的this一般指向window
objTest.timeout();
  1. call和apply中括号里面的第一个参数是谁this就指向谁。
let oldObjec = {
    name: 'oldObjec',
    age: 1000,
    getName: function() {
        console.log('oldObjec getName', this.name);
    }
};
let newObjec = {
    name: 'newObjec',
    age: 00,
    getAge: function () {
        console.log('newObjec getAge', this.age);
    }
};
let name = 'window';
oldObjec.getName.call(newObjec); //输出newObjec,说明this指向的是newObjec
newObjec.getAge.call(oldObjec);//输出1000, 说明this指向的是oldObject
  1. 箭头函数中的this,就是定义是所在的对象,而不是使用时所在的对象
var age = 111;
function getName () {
setTimeout(() => {
        console.log('arrowObjec getName', this.age);
    }, 1000);
}
getName.call({age: 2000});

大煜儿
103 声望7 粉丝

用心走路,给每一个细节打一个结。


« 上一篇
对象复制
下一篇 »
json