javascript - 问一个比较简单的js原生题目
PHP中文网
PHP中文网 2017-04-11 11:31:41
[JavaScript讨论组]



    




    

为什么加了settimeout以后输出的是全局变量的id

PHP中文网
PHP中文网

认证高级PHP讲师

全部回复(8)
伊谢尔伦

obj.cool 作为一个引用 传递个setTimeout, setTimeout 调用这个函数的时候是 '函数调用(而不是方法调用)' 所以this指向全局对象

怪我咯
var obj = {
    id:"aw",
    cool:function coolFn(){
        console.log(this.id);
    }
}
var id = 'not  aw';
setTimeout(obj.cool,100);

上面的代码this是相当于

var obj = {
    id:"aw",
    cool:function coolFn(){
        console.log(this.id);
    }
}
var id = 'not  aw';
var func = obj.cool;
setTimeout(func ,100);

真正调用cool方法的是window,this指向调用者,所以打印出来的是window.id

PHP中文网

因为这个this是指向window

大家讲道理

怪我知识短浅,我只知道,setTimeout() 和 setInterval() 调用的代码或者函数是全局作用域的

巴扎黑

setTimeoutwindow对象所调用的

正所谓this指向调用它所在函数的那个对象

理解了这句话,就理解了this的指向

巴扎黑

普通函数的 this 不是定义时的,而是调用时的。

在控制台中运行下面的代码(不好意思哈,写代码不切换输入法,注释是英文的了):

function a0 () {
  console.log(this.x)
}

function a1 () {
  this.x = 'x'
  console.log(this.x)
}
a0() // global call, `this` is `window`, this.x is `undefined`
a1() // global call, `this` is `window`, this.x is 'x', and now `window` has a property x with value 'x'

var b = {x: 'y'}
a0.call(b) // `this` is `b`, prints: 'y', `b` is {x: 'y'}
a1.call(b) // `this` is `b`, prints: 'x', now `b` is {x: 'x'}!!!!
阿神

老生常谈的 this 问题了, obj.cool它的本质就是一个函数。

setTimeout(obj.cool,100); 《==》 setTimeout(function coolFn(){console.log(this.id))},100)
天蓬老师
var obj = {
            id:"aw",
            cool:function coolFn(){
                console.log(this.id);
            }
        }
        var id = 'not  aw';
        setTimeout(obj.cool.bind(obj),100);
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号