• <sub id="h4knl"><ol id="h4knl"></ol></sub>
    <sup id="h4knl"></sup>
      <sub id="h4knl"></sub>

      <sub id="h4knl"><ol id="h4knl"><em id="h4knl"></em></ol></sub><s id="h4knl"></s>
      1. <strong id="h4knl"></strong>

      2. javascript中new操作符的原理

        時間:2024-08-19 11:19:39 JavaScript 我要投稿
        • 相關推薦

        javascript中new操作符的原理

          javascript中new操作符的原理

          javascript中的new是一個語法糖,對于學過c++,java 和c#等面向對象語言的人來說,以為js里面是有類和對象的區別的,實現上js并沒有類,一切皆對象,比java還來的徹底

          new的過程實際上是創建一個新對象,把新象的原型設置為構造器函數的原型,在使用new的`過程中,一共有3個對象參與了協作,構造器函數是第一個對象,原型對象是二個,新生成了一個空對象是第三個對象,最終返回的是一個空對象,但這個空對象不是真空的,而是已經含有原型的引用(__proto__)

          步驟如下:

          (1) 創建一個空對象obj

          (2) 讓空對象的__proto__(IE沒有該屬性)成員指向了構造函數的prototype成員對象

          (3) 使用apply調用構造器函數,this綁定到空對象obj上。

          (4) 返回空對象obj

          可以自己寫個函數替代使用new也是完全可以的,示例代碼如下:

          function NEW_OBJECT(Foo){var obj={};obj.__proto__=Foo.prototype;obj.__proto__.constructor=Foo;Foo.apply(obj,arguments)return obj;}

          以上這篇淺談javascript中new操作符的原理就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持。

        【javascript中new操作符的原理】相關文章:

        JavaScript中的with關鍵字07-24

        在Java中執行JavaScript代碼07-14

        Javascript中typeof 用法歸納09-27

        JavaScript 小型打飛機游戲實現和原理說明08-18

        抽象語法樹在JavaScript中的應用08-18

        JavaScript中的三種對象10-24

        perl- javascript中class的機制05-03

        JavaScript中push(),join() 函數實例詳解09-05

        詳解JavaScript中的splice()使用方法08-20

        javascript中for/in循環以及常見的使用技巧06-24

        国产高潮无套免费视频_久久九九兔免费精品6_99精品热6080YY久久_国产91久久久久久无码
      3. <sub id="h4knl"><ol id="h4knl"></ol></sub>
        <sup id="h4knl"></sup>
          <sub id="h4knl"></sub>

          <sub id="h4knl"><ol id="h4knl"><em id="h4knl"></em></ol></sub><s id="h4knl"></s>
          1. <strong id="h4knl"></strong>

          2. 亚洲国产中文一卡二卡三卡免费 | 最新69国产精品视频免费 | 亚洲高清AV一区二区三区 | 亚洲香蕉午夜国产理论电影 | 亚洲国产色福利网 | 亚洲另类欧美综合久久图片区 |

            javascript中new操作符的原理

              javascript中new操作符的原理

              javascript中的new是一個語法糖,對于學過c++,java 和c#等面向對象語言的人來說,以為js里面是有類和對象的區別的,實現上js并沒有類,一切皆對象,比java還來的徹底

              new的過程實際上是創建一個新對象,把新象的原型設置為構造器函數的原型,在使用new的`過程中,一共有3個對象參與了協作,構造器函數是第一個對象,原型對象是二個,新生成了一個空對象是第三個對象,最終返回的是一個空對象,但這個空對象不是真空的,而是已經含有原型的引用(__proto__)

              步驟如下:

              (1) 創建一個空對象obj

              (2) 讓空對象的__proto__(IE沒有該屬性)成員指向了構造函數的prototype成員對象

              (3) 使用apply調用構造器函數,this綁定到空對象obj上。

              (4) 返回空對象obj

              可以自己寫個函數替代使用new也是完全可以的,示例代碼如下:

              function NEW_OBJECT(Foo){var obj={};obj.__proto__=Foo.prototype;obj.__proto__.constructor=Foo;Foo.apply(obj,arguments)return obj;}

              以上這篇淺談javascript中new操作符的原理就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持。