zoukankan      html  css  js  c++  java
  • JavaScript中this

    全局this

    浏览器宿主的全局环境中,this指的是window对象。

    <script type="text/javascript">

      console.log(this === window); //true

    </script>

    浏览器中在全局环境下,使用var声明变量其实就是赋值给thiswindow

    <script type="text/javascript">

      var foo = "bar";

      console.log(this.foo); //logs "bar" console.log(window.foo); //logs "bar"

    </script>

    任何情况下,创建变量时没有使用var或者let(ECMAScript 6),也是在操作全局this

    <script type="text/javascript">

      foo = "bar";

      function testThis() {

        foo = "foo";

      }

      console.log(this.foo); //logs "bar" testThis();

      console.log(this.foo); //logs "foo"

    </script>

    除了DOM的事件回调或者提供了执行上下文(后面会提到)的情况,函数正常被调用(不带new)时,里面的this指向的是全局作用域。

    <script type="text/javascript">

    foo = "bar";

      function testThis() {

        this.foo = "foo";

      }

      console.log(this.foo); //logs "bar"

      testThis();

      console.log(this.foo); //logs "foo"

    </script>

     当用调用函数时使用了new关键字,此刻this指代一个新的上下文,不再指向全局this

    <script type="text/javascript">

      foo = "bar";

      function testThis() {

      this.foo = "foo";

      }

      console.log(this.foo); //logs "bar"

      new testThis();

      console.log(this.foo); //logs "bar"

      console.log(new testThis().foo); //logs "foo"

      </script>

     

     

    函数创建后其实以一个函数对象的形式存在着。

    既然是对象,则自动获得了一个叫做prototype的属性,可以自由地对这个属性进行赋值。

    当配合new关键字来调用一个函数创建实例后,此刻便能直接访问到原型身上的值。

    function Thing() {

      console.log(this.foo);

    }

      Thing.prototype.foo = "bar";

      var thing = new Thing(); //logs "bar"

      console.log(thing.foo); //logs "bar"

    当通过new的方式创建了多个实例后,他们会共用一个原型。比如,每个实例的this.foo都返回相同的值,直到this.foo被重写。

    function Thing() { }

    Thing.prototype.foo = "bar";

    Thing.prototype.logFoo = function () {

      console.log(this.foo);

    }

    Thing.prototype.setFoo =

    function (newFoo) {

      this.foo = newFoo;

    }

    var thing1 = new Thing();

    var thing2 = new Thing();

    thing1.logFoo(); //logs "bar"

    thing2.logFoo(); //logs "bar"

    thing1.setFoo("foo");

    thing1.logFoo(); //logs "foo";

    thing2.logFoo(); //logs "bar";

    thing2.foo = "foobar";

    thing1.logFoo(); //logs "foo";

    thing2.logFoo(); //logs "foobar";  

    ...或者不通过实例,直接操作函数的原型。

    function Thing() { }

    Thing.prototype.foo = "bar";

    Thing.prototype.logFoo = function () { console.log(this.foo, Thing.prototype.foo); }

    var thing = new Thing();

    thing.foo = "foo"; thing.logFoo(); //logs "foo bar";

     

     

     

     

  • 相关阅读:
    c/c++设置图片为透明图
    转;说说AngularJS中的$parse和$eval
    转: css3: display:box详解
    转: 深入理解 AngularJS 的 Scope
    转:说说angularjs中的$parse和$eval
    转: 理解AngularJS中的依赖注入
    angularjs学习总结(快速预览版)
    XML基础知识
    读书笔记:js设计模式
    contains 和 ele.compareDocumentPosition确定html节点间的关系
  • 原文地址:https://www.cnblogs.com/zhaoleigege/p/4775305.html
Copyright © 2011-2022 走看看