JavaScript嵌套函数this的重定向

本文探讨了在JavaScript嵌套函数中,this的指向问题。当在嵌套函数内部,this不再指向预期的对象,导致错误。解决这个问题的方法包括:1) 保存外部函数的this到一个变量;2) 使用.bind()方法绑定this;3) 在使用数组方法如forEach时,利用其内置的回调函数。如有疑问,可联系作者decadecode@foxmail.com。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在嵌套函数里,this的指向已经不是那么的明朗了。
看下面一段代码。

var obj = {
    name: 'Jane',
    friends: [ 'Tarzan', 'Cheeta' ],
    loop: function () {
        'use strict';
        this.friends.forEach(
            function (friend) {  
                console.log(this.name+' knows '+friend);  
            }
        );
    }
};
obj.loop();//Cannot read property 'name' of undefined

这里就直接报错了。
至于为什么,直接看下面一段代码。

var obj = {
    name: 'Jane',
    friends: [ 'Tarzan', 'Cheeta' ],
    loop: function () {
        'use strict';
console.log(this);.//Object {name: "Jane", friends: Array[2]}
        this.friends.forEach(
            function (friend) {  
console.log(this);//undefined
                console.log(this.name+' knows '+friend);  
            }
        );
    }
};
obj.loop();

可以看出来,因为嵌套的原因,嵌套函数里的this已经没有指向任何对象了。解决这个问题,有三个方法。
1:在进入嵌套函数前,将当前的this保存在一个变量中。

var obj = {
    name: 'Jane',
    friends: [ 'Tarzan', 'Cheeta' ],
    loop: function () {
        'use strict';
        var that = this ;
        this.friends.forEach(
            function (friend) {  
                console.log(that.name+' knows '+friend);  
            }
        );
    }
};
obj.loop();//这样可以正常输出

2:使用bind().

var obj = {
    name: 'Jane',
    friends: [ 'Tarzan', 'Cheeta' ],
    loop: function () {
        'use strict';
        this.friends.forEach(
            function (friend) {  
                console.log(this.name+' knows '+friend);  
            }.bind(this)
        );
    }
};
obj.loop();//这样可以正常输出

3:使用forEach的callback,详情请看 Examination Methods

var obj = {
    name: 'Jane',
    friends: ['Tarzan', 'Cheeta'],
    loop: function() {
        'use strict';
        this.friends.forEach(function(friend) {
            console.log(this.name + ' knows ' + friend);
        }, this);
    }
};
obj.loop();

有任何问题可以跟我留留言:decadecode@foxmail.com

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值