this打印

node和浏览器运行的区别

1.浏览器环境是 this===window 创建GO对接console.log(this)===console.log(window)

2.node环境{}空对象,console.log(window) 报错,console.log(this) {}空对象

this 到底指向

  1. 函数调用是,js默认给this绑定一个值
  2. this的绑定和定义的位置没有关系
  3. this的绑定和调用方式以及调用的位置有关系
     var obj = {
          name: 'why',
          foo: function () {
            console.log(this)
          },
        }
        var obj2 = {
          name: 'obj2',
          bar: obj.foo,
        }
        obj2.bar() //this指向obj2和调用位置有关
    var obg={
    name:'why',
    foo:function(){
    console.log(this)
    }
    }
    
    var bar=obg.foo
    bar()//独立调用所以this指向window
    
    
    var obg={
    name:'why',
    foo:function(){
    console.log(this)
    }
    }
    
    obg.foo() //指向obg
    

  4. this是在运行时被绑定
  5. 默认绑定
    function foo(){console.log(this)}
    foo()
    默认指向window
  6. 隐式绑定
    var obg={
    name:'why',
    foo:function(){
    console.log(this)
    }
    }
    
    obg.foo() //指向obg 隐式绑定
    
     var obj = {
          name: 'why',
          foo: function () {
            console.log(this)
          },
        }
        var obj2 = {
          name: 'obj2',
          bar: obj.foo,
        }
        obj2.bar() //指向obj2 和调用位置有关 隐式绑定
  7. 显示绑定
    1.方法
    var obj = {
          name: 'obj',
        }
        function foo() {
          console.log(this)
        }
      //执行函数有并且可以通过call和apply,bind改变this的指向
       foo.call()
        foo.apply()
        foo()
    
        foo.call('obj')
        foo.apply('1231')
    2.方法2
      var obj = {
          name: '12312',
        }
        function foo(num, num2) {
          console.log(this, num2, obj.name, this.name)
        }
    //call 参数传的是字符串 apply参数传的是数组
        foo.call(obj, 123, 666)
        foo.apply(obj, [123, 666])
    
    //bind改变this的值//每次执行都返回新的对象
       var obj = {
          name: '12312',
        }
        function foo() {
          console.log(this)
        }
        var newFn = foo.bind(obj)
        newFn()
        newFn()
        newFn()
    //优化了方法1的写法
    foo.call('obj')
    foo.call('obj')
    foo.call('obj')
    
    //new绑定 this完成构造器的时候绑定的
     function Person(name) {
          this.name = name
        }
        var p1 = new Person(213)
        var p2 = new Person(123)
        console.log(p1, p2)
    
    

  8. new绑定
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

叮咚前端

你的鼓励是我们的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值