<font id="zqva1"></font>
<rt id="zqva1"></rt>
  • <tt id="zqva1"></tt>
    <cite id="zqva1"></cite>

    <cite id="zqva1"><noscript id="zqva1"></noscript></cite>
      <rp id="zqva1"><meter id="zqva1"></meter></rp>

        <cite id="zqva1"></cite>
          <b id="zqva1"></b>
          <rp id="zqva1"></rp>
          <cite id="zqva1"></cite>

          <rt id="zqva1"></rt>

        1. <rp id="zqva1"></rp>

          Js中constructor指向問題

          時間:?2019-09-23閱讀:?199標簽:?js知識

          首先用一個例子指出來constructor存在形式。

          function Fruit(){ }
          var f=new Fruit();
          console.log(f.constructor);//打印出Fruit()

          由上面的代碼我們總結出結論1:上面的代碼在控制臺可以看出constructor是指向構造器Fruit的引用。

          function Fruit(){ this.name="水果"}
          //var f=new Fruit();
          function Apple(){this.name="蘋果";}
          Apple.prototype=new Fruit();
          var apple=new Apple();
          console.log(apple.constructor);//依然打印出Fruit()
          Apple.prototype={};//空對象的構造器是Object()
          apple=new Apple();
          console.log(apple.constructor);//指向Object()

          這個地方就有點奇怪了。這個constructor到底指向的是那個實例的構造器?

          根據上面的代碼總結出結論2:constructor指向的是原型對象的構造器的引用

             apple.constructor==Apple.prototype.constructor

          var apple2=new apple.constructor();
          console.log(apple2.name);

          或者

          var apple2=new Apple.prototype.constructor();
          console.log(apple2.name);

          打印的都是水果。

          我們現在想讓他執行的是蘋果的打印;這個時候就需要對constructor的指向進行重新指定。

          根據上面的兩個結論:無論是修改實例的constructor還是構造器的原型constructor屬性都是可以達到目的的

          可以在重寫了prototype屬性的代碼后寫下這樣的代碼

          Apple.prototype.constructor=Apple;

          或者在實例化后對實例的constructor進行重新制定。

           apple.constructor=Apple;

           雖然上面的兩種方式都能達到目的,但是推薦使用第一種。

          第二種方式需要有一個實例化的對象,而我們只用在對繼承的創建完成后才會去實例化,

          等有了實例化對象在去修改constructor,這個時候已經遲了,意義已經不大了,繼承的關系已經確定了。


          站長推薦

          1.阿里云: 本站目前使用的是阿里云主機,安全/可靠/穩定。點擊領取2000元代金券、了解最新阿里云產品的各種優惠活動點擊進入

          2.騰訊云: 提供云服務器、云數據庫、云存儲、視頻與CDN、域名等服務。騰訊云各類產品的最新活動,優惠券領取點擊進入

          3.廣告聯盟: 整理了目前主流的廣告聯盟平臺,如果你有流量,可以作為參考選擇適合你的平臺點擊進入

          鏈接: http://www.modern-decoration.com.cn/article/detial/7025

          javascript中什么是句柄?

          一個句柄是指使用的一個唯一的整數值,即一個4字節(64位程序中為8字節)長的數值,來標識應用程序中的不同對象和同類中的不同的實例。

          javascript不可變性是什么?

          不可變性即某個變量在進行了某個操作之后,其本身沒有發生變化,比如對于字符串而言,對字符串的任何操作都會改變字符串本身的值,而是在字符串的基礎上復制出來一個然后再改變,這樣我們就說是不可變的

          為什么javascript不起作用?

          JavaScript是一種屬于網絡的腳本語言,已經被廣泛用于Web應用開發,常用來為網頁添加各式各樣的動態功能,為用戶提供更流暢美觀的瀏覽效果。通常JavaScript腳本是通過嵌入在HTML中來實現自身的功能的。

          javascript怎么判斷按鈕被點擊?

          JavaScript可以通過Event對象的target事件或srcElement(IE瀏覽器支持)來判斷按鈕是否被點擊。Event對象代表事件的狀態,比如事件在其中發生的元素、鍵盤按鍵的狀態、鼠標的位置、鼠標按鈕的狀態。

          javascript由幾部分組成?

          JavaScript有三部分組成。分別為核心(ECMAScript) 、文檔對象模型(DOM)、瀏覽器對象模型(BOM)。這三部分分別描述了該語言的語法和基本對象、處理網頁內容的方法和接口、與瀏覽器進行交互的方法和接口。

          Js輸出方式有哪些?

          在編寫JavaScript代碼的時候, 一定要記住每一句代碼后面都需要添加一個分號, 并且這個分號必須是英文的分號,我們會發現有時候不寫分號程序也能夠運行, 這里并不是因為不需要分號, 而是瀏覽器自動幫助我們添加了分號

          7個常見的 JavaScript 測驗及解答

          我相信學習新事物并評估我們所知的東西對自己的進步非常有用,可以避免了我們覺得自己的知識過時的情況。在本文中,我將介紹一些常見的 JavaScript 知識。請享用!

          javascript難點是什么?

          javascript難點是什么?下面本篇文章就來給大家介紹一下10個JavaScript難點,感興趣的小伙伴們可以參考一下,希望對大家有所幫助。立即執行函數,即Immediately Invoked Function Expression (IIFE),正如它的名字

          Js如何獲取ul中li的個數?

          javascript如何獲取ul中li的個數?下面本篇文章就來給大家介紹一下使用javascript獲取ul中li個數的方法,希望對大家有所幫助。

          javascript怎么輸出?

          JavaScript怎么輸出?輸出方式有哪些?下面本篇文章就給大家介紹JavaScript的幾種輸出方式。window.alert()方法用于顯示帶有一條指定消息和一個【確認】 按鈕的警告框。

          內容以共享、參考、研究為目的,不存在任何商業目的。其版權屬原作者所有,如有侵權或違規,請與小編聯系!情況屬實本人將予以刪除!

          文章投稿關于web前端網站點搜索站長推薦網站地圖站長QQ:522607023

          小程序專欄: 土味情話心理測試腦筋急轉彎幽默笑話段子句子語錄成語大全運營推廣

          国产精品高清视频免费 - 视频 - 在线观看 - 影视资讯 - 唯爱网