搜索
javascript - 关于es6箭头函数的一些小问题
PHPz
PHPz 2017-04-11 12:45:53
[JavaScript讨论组]
var id =21;
        function testThis(){
            setTimeout(function(){
                console.log(this.id);
            },1000);
        }
        let testThis2 = ()=>{
            setTimeout(function(){
                console.log(this.id);
            },1000);
        }
        function testThis3(){
            setTimeout(()=>{
                console.log(this.id);
            },1000);
        }
        testThis();
        testThis2();
        testThis3();
        testThis.call({id:42});
        testThis2.call({id:42});
        testThis3.call({id:42});

为什么 testThis2.call({id:42}); console的是21呢。

PHPz
PHPz

学习是最好的投资!

全部回复(3)
伊谢尔伦

因为看this首先看它所在的function, testThis2表面上自身是用了箭头函数,但只能说,testThis2的函数执行内容里的this可以按.call({id:42})绑定,而setTimeout里面还有一个function,里面的this是要看这个内部function的,不会去看testThis2的this的。
所以才有testThis3的做法嘛~

巴扎黑

箭头函数有几个使用注意点。

(1)函数体内的this对象,就是定义时所在的对象,而不是使用时所在的对象。

(2)不可以当作构造函数,也就是说,不可以使用new命令,否则会抛出一个错误。

(3)不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用Rest参数代替。

(4)不可以使用yield命令,因此箭头函数不能用作Generator函数。

上面四点中,第一点尤其值得注意。this对象的指向是可变的,但是在箭头函数中,它是固定的。

http://es6.ruanyifeng.com/#do...箭头函数 用之前多看看

阿神

因为在箭头函数中,this的指向是固定的,在testThis2函数是引用,引用的是箭头函数,箭头函数的this指向外面的21,所以此时this指向windows对象

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

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