」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 為什麼 JavaScript 中包含物件的陣列「typeof」會回傳「Object」?

為什麼 JavaScript 中包含物件的陣列「typeof」會回傳「Object」?

發佈於2024-11-08
瀏覽:392

Why Does `typeof` Return \

理解矛盾:為什麼帶有物件的typeof 陣列會傳回「Object」

開發者可能會遇到一個令人驚訝的現象:在數組上呼叫typeof 時包含對象,它莫名其妙地返回“對象”而不是“數組”。本文深入探討了這種看似矛盾的行為。

透過一個例子來說明這個問題:

$.ajax({
    url: 'http://api.twitter.com/1/statuses/user_timeline.json',
    data: { screen_name: 'mick__romney'},
    dataType: 'jsonp',
    success: function(data) {
        console.dir(data); //Array[20]
        alert(typeof data); //Object
    }
});

雖然 console.dir(data) 正確地將變數識別為數組,但 typeof data 不協調地傳回「Object」。

解釋在於 JavaScript 的特殊規範,其中 typeof 運算子傳回物件內部 [[Class]] 屬性的型別。對於數組,它們的 [[Class]] 屬性設定為“Array”,但當被物件包圍時,[[Class]] 屬性變更為“Object”。

確保準確的類型檢查,開發人員可以採用多種方法:

  • data instanceof Array:檢查變數是否為 Array 類型的實例。
  • Array.isArray(data):一種方法專門設計用於確定物件是否為陣列。
  • Object.prototype.toString.call(data) == '[object Array]':一種可靠且廣泛接受的陣列檢測方法。
  • $.isArray(data):一個專門用來檢查陣列的 jQuery 函數。

透過理解這種特性並利用這些技術,開發人員可以有效地處理陣列JavaScript 程式碼中的物件。

最新教學 更多>
  • 如何增加 PHP 最大 POST 變數限制?
    如何增加 PHP 最大 POST 變數限制?
    PHP最大POST變數限制處理具有大量輸入欄位的POST請求時,當變數數量超過預設值時,會出現常見問題PHP 中的限制。例如,超過 1000 個欄位的表單可能只會公開 $_POST 陣列中的前 1001 個變數。 要解決此問題,需要調整 PHP 允許的 POST 變數的最大數量。在版本 5.3.9 ...
    程式設計 發佈於2024-11-09
  • 為什麼 OpenX 儀表板顯示「錯誤 330 (net::ERR_CONTENT_DECODING_FAILED)」?
    為什麼 OpenX 儀表板顯示「錯誤 330 (net::ERR_CONTENT_DECODING_FAILED)」?
    錯誤330 (net::ERR_CONTENT_DECODING_FAILED):解開壓縮問題遇到神祕的「錯誤330 (net::ERR_CONTENT_DER_CONTENT_DEDING_&&&B) ” “導航到儀表板時頁面,有必要深入研究根本原因。伺服器錯誤識別HTTP 請求中使用的內容壓縮方...
    程式設計 發佈於2024-11-09
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-09
  • 如何在Java中使用堆疊將算術表達式解析為樹結構?
    如何在Java中使用堆疊將算術表達式解析為樹結構?
    在Java 中將算術表達式解析為樹結構從算術表達式創建自定義樹可能是一項具有挑戰性的任務,特別是在確保樹結構時準確反映表達式的操作和優先順序。 要實現這一點,一種有效的方法是使用堆疊。以下是該過程的逐步描述:初始化:從空堆疊開始。 處理代幣:迭代表達式中的每個標記:如果標記是左括號,則壓入它 如果t...
    程式設計 發佈於2024-11-09
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-09
  • 如何進行有替換和無替換的有效加權隨機選擇?
    如何進行有替換和無替換的有效加權隨機選擇?
    帶有替換和不帶替換的加權隨機選擇為了應對編程挑戰,我們尋求從列表中進行加權隨機選擇的有效演算法,帶替換的加權選擇帶替換的加權選擇的一種有效方法是別名方法。此技術為每個加權元素建立一組相同大小的箱子。透過利用位元操作,我們可以有效地索引這些容器,而無需訴諸二分搜尋。每個 bin 儲存一個百分比,表示原...
    程式設計 發佈於2024-11-09
  • 如何在不依賴框架的情況下確定 DOM 準備?
    如何在不依賴框架的情況下確定 DOM 準備?
    Document.isReady:DOM 就緒偵測的本機解決方案依賴Prototype 和jQuery 等框架來管理window.onload 事件可能不會總是令人嚮往。本文探討了確定DOM 就緒情況的替代方法,特別是透過使用document.isReady.查詢Document.isReady對於...
    程式設計 發佈於2024-11-09
  • 如何在 Golang 中檢索 XML 陣列中的所有元素而不僅限於第一個元素?
    如何在 Golang 中檢索 XML 陣列中的所有元素而不僅限於第一個元素?
    在XML 中解組數組元素:檢索所有元素,而不僅僅是第一個當使用xml.Unmarshal( 在Golang 中解組XML 陣列時[]byte(p.Val.Inner), &t),您可能會遇到僅檢索第一個元素的情況。若要解決此問題,請利用 xml.Decoder 並重複呼叫其 Decode 方法。 解...
    程式設計 發佈於2024-11-09
  • 帶有管理面板的輕量級 Rest Api,可輕鬆管理食物食譜。
    帶有管理面板的輕量級 Rest Api,可輕鬆管理食物食譜。
    你好, ?所有這篇文章都是關於我剛剛在 Github 上發布的 Django Rest Framework API。 如果您正在尋找一些簡單且高效的 API 來從管理面板管理食物食譜並將其返回以供客戶端使用,那麼此儲存庫適合您。 該程式碼是輕量級的,可以在任何低功耗迷你 PC(如 Raspbe...
    程式設計 發佈於2024-11-09
  • 如何使用正規表示式來匹配帶有或不帶有可選 HTTP 和 WWW 前綴的 URL?
    如何使用正規表示式來匹配帶有或不帶有可選 HTTP 和 WWW 前綴的 URL?
    使用可選 HTTP 和 WWW 前綴匹配 URL正則表達式是執行複雜模式匹配任務的強大工具。當涉及到符合 URL 時,格式通常會有所不同,例如是否包含「http://www」。 使用正規表示式的解決方案匹配帶或不帶「http://www」的 URL。前綴,可以使用以下正規表示式:((https?|f...
    程式設計 發佈於2024-11-09
  • 如何在不依賴副檔名的情況下確定檔案類型?
    如何在不依賴副檔名的情況下確定檔案類型?
    如何在不依賴副檔名的情況下偵測檔案類型除了檢查檔案的副檔名之外,確定檔案是mp3 還是圖像格式是很有價值的程式設計中的任務。這是一個不依賴擴充的全面解決方案:PHP >= 5.3:$mimetype = finfo_fopen(fopen($filename, 'r'), FILEINFO_MIME...
    程式設計 發佈於2024-11-09
  • 在 JavaScript 中實作斐波那契數列:常見方法和變體
    在 JavaScript 中實作斐波那契數列:常見方法和變體
    作為開發人員,您可能遇到過編寫函數來計算斐波那契數列中的值的任務。這個經典問題經常出現在程式設計面試中,通常要求遞歸實現。然而,面試官有時可能會要求具體的方法。在本文中,我們將探討 JavaScript 中最常見的斐波那契數列實作。 什麼是斐波那契數列? 首先,讓我們回顧一下。斐波...
    程式設計 發佈於2024-11-09
  • 如何使用 .htaccess 更改共享伺服器上的 PHP 版本?
    如何使用 .htaccess 更改共享伺服器上的 PHP 版本?
    在共享伺服器上透過.htaccess 更改PHP 版本如果您正在操作共享伺服器並且需要更改PHP 版本,可以透過.htaccess文件來做到這一點。這允許您為您的網站運行特定的 PHP 版本,同時伺服器維護其預設版本。 要切換 PHP 版本,請按照下列步驟操作:找到 . htaccess 檔案: 該...
    程式設計 發佈於2024-11-09
  • 如何在Ajax資料載入過程中顯示進度條?
    如何在Ajax資料載入過程中顯示進度條?
    如何在Ajax 資料載入期間顯示進度條處理使用者觸發的事件(例如從下拉方塊中選擇值)時,通常會使用非同步擷取資料阿賈克斯。在獲取數據時,向用戶提供正在發生某事的視覺指示是有益的。本文探討了一種在 Ajax 請求期間顯示進度條的方法。 使用 Ajax 實作進度條要建立一個準確追蹤 Ajax 呼叫進度的...
    程式設計 發佈於2024-11-09
  • TCJavaScript 更新、TypeScript Beta、Node.js 等等
    TCJavaScript 更新、TypeScript Beta、Node.js 等等
    歡迎來到新一期的「JavaScript 本週」! 今天,我們從 TC39、Deno 2 正式版本、TypeScript 5.7 Beta 等方面獲得了一些針對 JavaScript 語言的巨大新更新,所以讓我們開始吧! TC39 更新:JavaScript 有何變化? 最近在東京...
    程式設計 發佈於2024-11-09

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3