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内的方法

 

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

  1. js中修改this指向的方法(call,apply,bind)

    前言:call.apply和bind都是为了改变某个函数运行时的this指向的,对于前端人员来说,关于this的掌握程度,直接决定了前端水平的高低.下面我们就来简单浅显易懂的来看一下es5中常用的三种 ...

  2. js中改变this指向的call、apply、bind 方法使用

    前言: 由于js 中this的指向受函数运行环境的影响,指向经常改变,使得开发变得困难和模糊,所以在封装sdk,写一些复杂函数的时候经常会用到this 指向绑定,以避免出现不必要的问题,call.ap ...

  3. js中this的指向

    在js中this的指向对于新手来说一定是个难题,但是如果你真正理解了的话,也就没什么问题啦,下面就来讲讲this吧. JS中,this的值取决于调用的模式(调用对象),而JS中共有4种调用模式: 1. ...

  4. JS中的this 指向问题

    我发现在对JS的学习中有很多朋友对this的指向问题还是有很大的误区或者说只是大致了解,但是一旦遇到复杂的情况就会因为this指向问题而引发各种bug. 对于之前学习过c或者是Java的朋友来说可能这 ...

  5. 理解js中this的指向

         学习自原文  http://www.cnblogs.com/pssp/p/5216085.html后的一点小结(原文作者总结的很棒^_^)! 关于js中this的指向,在函数定义的时候还无法 ...

  6. 轻松了解JS中this的指向

    JS中的this指向一直是个让人头疼的问题,想当初我学的是天昏地暗,查了好多资料,看的头都大了,跟他大战了那么多回合,终于把它搞定个七八分,其实往往都是我们复杂化了,现在就让大家轻松看懂this的指向 ...

  7. js中 this 的指向

    js中 this的指向一共存在3种地方: 1.全局的this; 2.构造函数的this; 3.call/apply; 一.全局的this: function test(){ this.d = 3;// ...

  8. JS 中的this指向问题和call、apply、bind的区别

    this的指向问题 一般情况下this对象指向调用函数的对象,全局环境中执行函数this对象指向window. function a(){ console.log(this); //输出函数a中的th ...

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

    首先必须要说的是,this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象(这句话有些问题,后面会解释为什么会有问题,虽然 ...

随机推荐

  1. Excel催化剂开源第32波-VSTO开发的插件让WPS顺利调用的方法-注册表增加注册信息

    VSTO插件开发完成后,鉴于现在WPS用户也不少,很多时候用户没办法用OFFICE软件,只能在WPS环境下办公,VSTO开发的插件,只需增加一句注册表信息,即可让WPS识别到并调用VSTO开发的功能, ...

  2. 个人永久性免费-Excel催化剂功能第28波-工作薄瘦身,安全地减少非必要冗余

    Excel催化剂在完善了数据分析场景的插件需求后,决定再补充一些日常绝大多数Excel用户同样可以使用到的小功能,欢迎小白入场,在不违背太多Excel最佳实践的前提下,Excel催化剂乐意为广大Exc ...

  3. [剑指offer] 34. 第一个只出现一次的字符

    题目描述 在一个字符串(0<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写). 一次遍历存储到哈希表 一次 ...

  4. sql注入篇1

    一.前言 学习了感觉很久的渗透,总结一下sql注入,系统整理一下sql注入思路. 二.关于sql注入 所谓SQL注入,就是通过把SQL命令插入到Web表单提交或输入域名或页面请求的查询字符串,最终达到 ...

  5. 基于Bitnami gitlab OVA包的gitlab 环境搭建

    前言 最近在折腾gitlab,本篇记录搭建的过程方便以后查找 环境 Windows server + VMware 安装 为方便本次我们直接采用Bitnami的VOA安装包(VOA格式可同时兼容Vir ...

  6. K2 smarforms 控件整理

    K2 Community – Market – Smatform Controls l   K2 blackpearl 1.    Drag and Drop Upload Control http: ...

  7. HTML页面中的布局问题

    在做网站中,给整个大的框架宽度设置为100%,然后设置body的最小宽度是网站的内容部分的宽度.网站内容的宽度是固定的.

  8. asn1 学习笔记

    语法 定义 Name ::= type 定义一个名称为“Name”的元素 它是一个给定ASN.1类型“Type”的实例 MyName ::= IA5String //IA5String(类似于ASCI ...

  9. Codeforces Round #486 (Div. 3) C "Equal Sums" (map+pair<>)

    传送门 •题意 给k个数列,从中k个数列中找出任意2个数列 i ,j 使得数列i删除第x个数,和数列j删除第y个数的和相等 若存在,输出 i ,x 和 j,y •思路 每个数列之间的联系为数列的和之间 ...

  10. SSD+HDD 安装ubuntu16.04+win7双系统

    本人电脑是联想天逸100  前段时间把光驱拆了加了一个128G的SSD 顺便把SSD装上了win7  机械硬盘500G放资料和一般软件之类的   后来想要用到ubuntu  就在官网下载ubuntu1 ...