javascript中constructor指向問題

来源:https://www.cnblogs.com/guoyansi19900907/archive/2019/12/23/12089151.html
-Advertisement-
Play Games

首先用一個例子指出來constructor存在形式。 由上面的代碼我們總結出結論1:上面的代碼在控制台可以看出constructor是指向構造器Fruit的引用。 這個地方就有點奇怪了。這個constructor到底指向的是那個實例的構造器? 根據上面的代碼總結出結論2:constructor指向的 ...


首先用一個例子指出來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,這個時候已經遲了,意義已經不大了,繼承的關係已經確定了。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • offset系列:獲取元素的寬,高,left,top, offsetParent offsetWidth:元素的寬,有邊框 offsetHeight:元素的高,有邊框 offsetLeft:元素距離左邊位置的值 offsetTop:元素距離上面位置的值 scroll系列:卷曲出去的值 scrollL ...
  • 1.引入方式不同 query要用path來引入 this.$router.push({ path: 'test', query: { type: 2, detail: '哈哈' } }) params要用name來引入 params要用name來引入 this.$router.push({ name ...
  • var map = {}; map['key1']=value1; map['key2']=value2; map['key3']=value3; map['key4']=value4; map['key5']=value5; 問題解決! ...
  • 對於CSS的white space屬性,我想大部分人應該和我差不多,最常用的就是nowrap屬性,最多用來做超長省略號顯示的時候會用到【hiahiahia~】 起因是這樣的:產品doggie策划了一個元旦活動,活動主頁最下邊需要顯示配置的活動規則,註意,是配置的活動規則,所以,免不了運營小妹要在後臺 ...
  • 為什麼我們要學習Node.js? 1. 認為: Node.js就學習一周,時間比較短,不重要 將來工作我後端又不用Node.js做,我們又java/python/php/c,為什麼要在意它 Node.js接下來項目中又不用,不用好好學,不用在意 2. 重要性? Node.js可以說是對js功能的擴展 ...
  • 1 <input type="date" id="date_info" placeholder="請輸入時間"/> 2 3 ...... 4 5 <script> 6 $(document).ready(function () { 7 var time = new Date(); 8 var day ...
  • 1.側邊欄划出一個信息框 通常滑鼠浮動側邊欄都會划出一個信息框,每個信息框距離側邊欄的距離是相等的,所以處理此問題的方法就是 量取信息框距離側邊欄的距離,信息框設置絕對定位,父元素設置相對定位之後,信息框就會相對於父元素的相對定位進行絕對定位,取父元素的width:100%,然後加上距離信息框距離側 ...
  • 對於更簡單的Ajax調用,XMLHttpRequest是低級別的,更複雜的,並且你需要封裝函數。不幸的是,一旦你開始考慮超時,中止調用和錯誤捕獲的複雜性,Fetch也會如此。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...