js中的this指向

 // 1,默认绑定规则

        function test1() {

            console.log(this);

        }

        test1();

        (function() {

            console.log(this);

        })()

默认绑定规则是指向window的,比如函数的独立调用,定时器,立即指向函数

        // 2,隐式绑定规则

        let obj1 = {

            name: 'zhangsan',

            foo: () => {

                console.log(this, '+');

                // function test2() {

                //     console.log(this);

                // }

                // test2()

            }

        }

        obj1.foo()

        console.log('--------------------------------------------');

        let obj2 = {

            name: 'zhangsan',

            foo: function() {

                console.log(this, '+');

                function test2() {

                    console.log(this);

                }

                test2()

                function test3() {

                    console.log(this);

                }

                return test3

            }

        }

        obj2.foo()

        obj2.foo()()

        console.log('---------------------');

        let bar1 = obj2.foo

        bar1()

        console.log('---------');

        let bar2 = obj2.foo()

        console.log('--------------------------------');

        function test4() {

            console.log(this);

        }

        let bar3 = {

            foo: test4

        }

        function test5(fn) {

            console.log(this);

            fn()

        }

        test5(bar3.foo)

        console.log("---------------------------------------------------------------------");

隐式调用一般是谁调用就会指向谁,但是向箭头函数旧特殊速,它没有自己的this,他中的this指向是上一个函数的this指向

        // 3,显示转化

        function test6() {

            console.log(this);

        }

        test6.call(obj1, 1, 2, 3)

        test6.apply(obj1, [1, 2, 3, 4, 5])

        test6.bind(obj1)(1, 2, 3)

显示转化一般是依赖call,apply,bind的函数去改变this指向,call和apply的区别是传的参数不同,call使用的更多它传参是列表,apply传参是数组,而bind不同于二者它会返回一个新函数,然后显示转化的优先级高于隐式转化

            //new实例化

        function test7(b) {

            this.a = b

        }

        let obj3 = new test7(3)

        console.log(obj3.a);

        console.log('-------------------------------');

        let test8 = () => {

            console.log(this);

        }

        let obj4 = {

            f: test8

        }

        obj4.f()

new中的this一般都是指向新的实例化对象,它 的优先级是高于隐式转换和显示转化的,究其原因好像是new的过程中也调用了显示转化,所以如果有显示转化new中的显示转化会覆盖旧的显示转化。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值