Welcome to OStack Knowledge Sharing Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
315 views
in Technique[技术] by (71.8m points)

关于this的指向

var a = 20;
var obj = {
    a: 10,
    c: this.a + 20,
    fn: function () {
         return this.a;
     }
}
            
console.log(obj.c);   //40
console.log(obj.fn());//10

第二个可以理解,第一个为什么是全局呢?


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Answer

0 votes
by (71.8m points)

看你上面的评论就能看出你没理解js中的this 在js中this的指向跟定义没关系 只取决于调用模式
console.log(obj.c);就相当于console.log(this.a+20) 在这种情况下 this毋庸置疑是指向全局的
第二种 console.log(obj.fn());//10是方法调用 this 就只想包含这个函数的对象

    1. 普通函数调用,this为全局对象或是undefined
    2. 作为对象的方法,this为那个对象
    3. new 表达式,this为以该函数为原型的新创建的对象
    4. 使用 apply/call指定 this
    5. 用bind绑定固定的this
    6. 事件处理函数中的this是当前的触发事件的DOM元素(event.currentTarget)

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome to OStack Knowledge Sharing Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...