美文网首页
一个比较复杂的js题目

一个比较复杂的js题目

作者: tsunamiGG | 来源:发表于2018-10-12 16:07 被阅读0次


    function Foo(){

    getName = function(){ alert(1); };

    return this;

    }

    Foo.getName = function(){ alert(2); };

    Foo.prototype.getName = function(){ alert(3); };

    var getName = function(){ alert(4); };

    function getName(){ alert(5) };

    Foo.getName();

    getName();

    Foo().getName();

    getName();

    new Foo.getName();

    new Foo().getName();

    new new Foo().getName();

    //结果依次输出为2 4 1 1 2 3 3


    //某些细节

    1、 this的指向只取决于调用的方式,,函数定义里面的this指向全局的window;

    new的过程:新建对象,让this指向它,返回this;

    普通的函数调用时得到的值是return的返回值,new 得到值可能是this也有可能是return 的值,这取决于return后面数据的类型。

    2、实例化对象访问一个属性的顺序,先看自身有没有这个属性,再看访问原型里的。

    3、new 后面跟的是一个构造函数,则会创建一个对象。如果是一个构造函数的属性名称,那么没有任何作用。

    new 只会和离他最近的()结合


    //结果分析

    一开始Foo.getName()为1,第5行代码将它修改为2,所以Foo.getName()的输出为2;

    getName() 是全局调用,函数提升优先于变量提升,到了第7行代码getName()被修改为4,所以输出为4;

    Foo()是函数调用,得到的是return后面的值this,this指向window,并且第2行代码将getName()修改为1,所以结果为1

    同理,getName()的输出也是为1;

    new Foo.getName() new没有任何作用,这里是方法调用,输出值为2

    new Foo().getName() new和最近的一个()结合,所以得到了一个实例化对象,实例化对象自身没有getName这个属性,所以访问原型里面的getName,为 3

    new new Foo().getName() 最前面的new没有任何意义,同上一个


    结语:这个题目主要涉及this在各种调用中的表现,能够更加清晰的理解this

    相关文章

      网友评论

          本文标题:一个比较复杂的js题目

          本文链接:https://www.haomeiwen.com/subject/yojgaftx.html