js中更改this指向 以及回顾bind、call和apply

1.更改this指向

  方法1:对this进行保存
               var _this = this;

       例: var _this = this;
             document.onclick = function(){
                  console.log(_this)
               }
             console.log(_this);

  方法2:bind   更改this指向。   返回的是一个函数体
           注意:  fn.bind(document)();   更改指向必须加()调用。

   例1:function fn(){
              console.log(this);
            }
        fn.bind(document)();

   例2:var obj = {
                show : function(){
                    console.log(this);
                }.bind(document)
            }

  方法3:call    更改this指向         fn.call(document);

      call(this指向,参数1,参数2,参数3,参数4)

      function fn1(a,b){
            return a + b;
          }
        function fn2(a,b){
              return a * b;
          }
        var res = fn2.apply(fn1,10,20);
         console.log(res);

  方法4:apply  更改this指向       fn.apply(document);

       apply(this指向,[值1,值2....])

  例1:
         function fn(){
           console.log(this);
            }
       fn.apply(document);

  例2:function fn1(a,b){
            return a + b;
          }
        function fn2(a,b){
              return a * b;
          }
        var res = fn2.apply(fn1,[10,20]);
         console.log(res);

总结:

更改this指向:
            bind     call    apply区别

bind :     返回的是一个函数体,    用必须加()调用;

call 和 apply的区别:
            所接收的参数不同
            call(this指向,参数1,参数2,参数3,参数4)
            apply(this指向,[值1,值2....])

2.call和apply回顾

  例1:function yasuo(name){

    this.name=name;

    this.skill=function(name){

      console.log(name+‘正在使用钢铁斩‘);

      }

    }

  var have =new yasuo(‘亚索‘);

    hove.skill();                            //亚索正在使用钢铁斩

  例2:

 function Yasuo(name){
         this.name = name;
         this.skill=function(){
          console.log(this.name+‘正在使用轻钢斩‘);
         }
   }
 function zhaoxin(name){
    this.name=name;
    Yasuo.call(this,name);
   }
   var hove=new zhaoxin(‘赵信‘);
    console.log( hove.skill);   //赵信正在使用钢铁斩

例3:

  function Yasuo(name){
           this.name = name;
      }
       Yasuo.prototype.skill = function(){}

   function Zhaoxin(name){
          this.name = name;
          Yasuo.apply(this)
     }

  var hore = new Zhaoxin();
       
       hore.skill(‘赵信‘);            //出错,

例4:

  function Person(name,age,id){
          this.name = name;
          this.age = age;
          this.id = id;
      }
      Person.prototype = {
          eat: function(){},
          sleep : function(){}
      }

  function Man(name,age,id,houjie){
          Person.call(this,name,age,id) 
          this.houjie = houjie;
          this.work = function(){
              console.log(‘男人的工作‘)
          }
      }

   var wangshuai = new Man(‘ws‘,‘20‘,‘111111‘,‘true‘);
      console.log(wangshuai);

            //   Man:

               age: "20"       houjie: "true"    id: "111111"          name: "ws"       work: ƒ ()         __proto__: Object

总结: call和apply 都可完成参数传递,

   call和apply 常用来继承属性,无法继承prototype内的方法

 

原文地址:https://www.cnblogs.com/wangwenxin123/p/10874877.html

时间: 2024-11-13 06:50:25

js中更改this指向 以及回顾bind、call和apply的相关文章

轻松了解JS中this的指向

JS中的this指向一直是个让人头疼的问题,想当初我学的是天昏地暗,查了好多资料,看的头都大了,跟他大战了那么多回合,终于把它搞定个七八分,其实往往都是我们复杂化了,现在就让大家轻松看懂this的指向,我会分以下几种情况来说. this的指向:  1 this 指的是调用当前方法(函数)的那个对象,也就是说函数在谁那被调用,this就指的是谁.   来看两个栗子: oBtn.onclick = function(){         alert(this);   //oBtn  } oBtn[i

理解js中this的指向

学习自原文  http://www.cnblogs.com/pssp/p/5216085.html后的一点小结(原文作者总结的很棒^_^)! 关于js中this的指向,在函数定义的时候还无法确定,只有在函数执行的时候才能确定this到底指向谁,实际上this最终指向的是调用它的对象. eg1: function a(){     var user = "xxxx";     console.log(this.user); //undefined     console.log(this

转:彻底理解js中this的指向,不必硬背

转:http://www.cnblogs.com/pssp/p/5216085.html 首先必须要说的是,this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象(这句话有些问题,后面会解释为什么会有问题,虽然网上大部分的文章都是这样说的,虽然在很多情况下那样去理解不会出什么问题,但是实际上那样理解是不准确的,所以在你理解this的时候会有种琢磨不透的感觉),那么接下来我会深入的探讨这个问题. 为什么要学习this?

彻底理解js中this的指向,不必硬背。

原文链接:http://www.cnblogs.com/pssp/p/5216085.html 首先必须要说的是,this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象(这句话有些问题,后面会解释为什么会有问题,虽然网上大部分的文章都是这样说的,虽然在很多情况下那样去理解不会出什么问题,但是实际上那样理解是不准确的,所以在你理解this的时候会有种琢磨不透的感觉),那么接下来我会深入的探讨这个问题. 为什么要学习th

JS 中 this 的指向

文章转载自: 作者:伯乐在线专栏作者 - 追梦子 链接:http://web.jobbole.com/88264/ 首先必须要说的是,this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象(这句话有些问题,后面会解释为什么会有问题,虽然网上大部分的文章都是这样说的,虽然在很多情况下那样去理解不会出什么问题,但是实际上那样理解是不准确的,所以在你理解this的时候会有种琢磨不透的感觉),那么接下来我会深入的探讨这个问题

JS中----this的指向和如何修改this的指向

this this是js中的一个关键字,函数运行时自动生成的一个内部对象,只能在函数内部使用.我们要讨论的是 this 的指向. this就是函数运行时自动生成的一个内部对象 下面介绍一下几种情况下,this的指向 1.全局环境 全局环境下,this就代表window对象.(针对web 应用来讲) var name = 'zhar'; function say(){ console.log(this.name);//zhar } say(); 同样,在 setTimeout 或 setInter

js 中this到底指向哪里?

其实js的this指向很简单.我们记住下面3种情况. this 指向的是浏览器中的window.代码如下: function fn(){ this.name='yangkun'; this.age=28; } 当我们执行fn()的时候,这个普通函数中的this指向到底是什么?答案就是指向的是浏览器中的window.(这里说明,这里实在浏览器下,如果是node环境不是). 如果这个时候我们对上面的函数进行进一步操作: function fn(){ this.name='yangkun'; this

了解Js中的this指向

Js中的this对象是在运行时基于函数的执行环境绑定的,其中的this指向很不好理解,一不小心就用错了位置;. this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象. 对于this指向的理解,我分以下几种情况来说, this的指向: 1.在全局函数中,this等于window: var name="cyp"; console.log(this); 2.当函数被用作为某个对象的方法调用时,this等于哪个对

Js中的this指向问题

函数中的this指向和当前函数在哪定义的或者在哪执行的都没有任何的关系分析this指向的规律如下: [非严格模式]1.自执行函数中的this永远是window [案例1] var obj={ fn:(function(i){ //this->window return function(){ //this->obj } })(0) }; obj.fn(); 2.给元素的某个行为绑定一个方法,当行为触发的时候,执行绑定的方法,此时方法中的this是当前的元素 [案例1] oDiv.onclick