• javascript中this指针详解


    谁调用的方法或者属性,this就指向谁

    如果没有被谁调用,this指向window

    情况1:如果一个函数中有this,但是它没有被上一级的对象所调用,那么this指向的就是window,这里需要说明的是在js的严格版中this指向的不是window,但是我们这里不探讨严格版的问题,你想了解可以自行上网查找。

    情况2:如果一个函数中有this,这个函数有被上一级的对象所调用,那么this指向的就是上一级的对象。

    情况3:如果一个函数中有this,这个函数中包含多个对象,尽管这个函数是被最外层的对象所调用,this指向的也只是它上一级的对象,如果不相信,那么接下来我们继续看几个例子。

    new操作符会让构造函数产生如下变化:

    1.       创建一个新对象;

    2.       将构造函数的作用域赋给新对象(因此this就指向了这个新对象);

    3.       执行构造函数中的代码(为这个新对象添加属性);

    4.       返回新对象

    首先看下面代码:

        

    复制代码
    function funcA() {
        this.name = "hello";
        console.log(this.name);
        this.show = function() {
            console.log(this.name);
        }
    }
    funcA();// 1、hello
    var a = new funcA();//2、hello
    a.show();//3、hello
    var objA = {
        name: "objA"
    }
    a.show.call(objA);//4、objA
    
    var objB = {
        name: "objB"
    }
    objB.show = a.show
    objB.show();//5、objB
    (objB.show = a.show)();//6、hello
    复制代码

    下面这几段代码就把this常见的情况给表现出来的差不多了, this在js中主要有四种用法:

    1、作为普通函数使用

    2、作为对象方法来使用

    3、call和apply

    4、作为构造函数来使用

    下面分别说明

    1、作为普通函数来使用:

    复制代码
     function funcA() {
        this.name = "hello";
        console.log(this.name);
        this.show = function() {
            console.log(this.name);
        }
    }
    funcA();// 1、hello
    复制代码

    这个代码很简单,但也隐藏了一个坑,就是这个时候的this 代表的是window的指针,所以当这段代码运行完之后,你再输出 console.log(window.name)时候,你会发现输出为”hello”,在使用中尽量避免。

    2、作为对象方法来使用

    var obj={name:"hello",show:function(){

    console.log(this.name);

    }};

    obj.show();

    这个很简单,this指向自己,所以this.name就用hello;

    如果代码修改下:

    复制代码
    var obj={name:"hello",show:function(){
        console.log(this.name);
    }};
    obj.show();
    
    var objA={name:"world"}
    objA.show=obj.show;
    objA.show()
    复制代码

    这个结果又是什么呢?答案是”world”,因为在js中对象都是引用类型,当objA.show=obj.show这句代码把objA.show也指向的show方法,所以在调用的时候会把this,指向objA而不是obj.

    3callapply

    这个在上面的继承中的原型冒充中也提过一些,这里也详细说明this在call和apply中微秒的用法:

    复制代码
    function funcA() {
        this.name = "hello";
        console.log(this.name);
        this.show = function() {
            console.log(this.name);
        }
    }
     
    var a = new funcA();
    a.show();
    var objA = {
        name: "objA"
    }
    a.show.call(objA);
    复制代码

    上面这段代码就是call的用法,这里我们可以把代码拆解成我们能看的懂的形式:

    a.show.call(objA)====>{
    obj.show=a.show();
    obj.show();
    delete obj.show();
    }

    上面就是call的类似执行的过程的形势(实际上并不是这样的,可以这样来记),知道了这个执行过程,我们就来探究这个的执行过程:

    1、把a.show里面的方法中的this全部换成obj.

    2、执行a.show(),同时把后面的参数作为参数处理。

    4、作为构造函数来使用

    复制代码
    function funcA(name){
        this.name;
        this.show=function(){
            console.log(name);
        }
    }
    var a=new funcA("hello");
    a.show();
    复制代码

     作为构造函数使用的时候,在new的关键字创建对象的时候,会先生成一个空对象,然后调用方法,把this的替换成这个空对象。(这个在上篇有详细的说明,这里不多说)。在创建对象的时候,this指针就指向了创建新对象。

    所以上面的那段代码我想应该就能看懂为什么会是这个输出结果了,唯一的有一个(objB.show = a.show)();这个比较奇怪,因为赋值的时候,返回的是右边的那个函数,所以最终执行的也是a.show();

    总结:js中的this其实是一个比较简单的东西,上面只列出了常用的东西,至于更深入的,可以自己在深入挖掘下,相信有了这个基础后,再深入的话应试就不是一件枯燥的事了

     

  • 相关阅读:
    解决ssh: connect to host github.com port 22: Connection refused
    sudo/su命令免密执行
    Linux tar.gz、tar、bz2、zip 等解压缩、压缩命令详解
    项目实战——校验文件名和邮箱地址
    项目实战:判断闰年平年并输出某月的天数
    ubuntu软件更新时出现没有Release文件
    项目实战:根据出生日期判断星座
    项目实战--实现淡旺季飞机票打折
    xxx.java:1: 错误: 类xxx是公共的, 应在名为 xxx.java 的文件中声明 public class xxx
    32位int整数范围
  • 原文地址:https://www.cnblogs.com/lina6251125/p/6384655.html
Copyright © 2020-2023  润新知