js中的this指向问题以及改变this指向

JS中的this 指向问题

代码解释:

<!-- <button>点击</button> -->
<script>
    var  Btn = document.getElementsByTagName("button")[0];

    Btn.onclick = function(){
        console.log(this);   //button 
        fun ()
    }

    function fun(){
        console.log(this);  //window可以理解全局的对象 
    }

    function per(){
        console.log(this);  // p1
        this.show();
    }

    per.prototype.show = function(){
        console.log(this); //p1
    }
    var p1 = new per();

    //定时器里的this
    setTimeout(function(){
        console.log(this);  //  window
    },1000) 

    //this指向的改变 :
 var a = {
     x : 1
 }
 var b = function(y,z){
     var x = 10;
     console.log(this.x + y + z)
 }
 b.call(a,3,4); //使用call()方法之后 将b的this指向给a,并且参数以逗号的形式传入
 b.apply(a,[3,4]); //使用apply()的方法, 将的this指向给a  参数以数字组的形式传入
 b.bind(a,3,4)(); //闭包的方式  将b的this 指向a
 
 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值