首頁 web前端 js教程 淺談es6 javascript的map資料結構_javascript技巧

淺談es6 javascript的map資料結構_javascript技巧

Dec 15, 2017 pm 02:06 PM
javascript js 資料結構

這篇文章主要介紹了淺談es6 javascript的map資料結構,小編覺得挺不錯的,現在分享給大家JavaScript源碼,也給大家做個參考。對JavaScript有興趣的一起跟隨小編過來看看吧

本文介紹了es6 javascript的map資料結構,分享給大家,具體如下:

##Map 結構的目的與基本用法

JavaScript 的物件( Object),本質上是鍵值對的集合( Hash 結構), 但傳統上只能用

字串當作鍵。 這給它的使用帶來了很大的限制。


var data = {}; 
var element = document.getElementById('myp'); 
data[element] = 'metadata'; 
data['[object HTMLpElement]'] // "metadata"
登入後複製


上面程式碼原意是將一個DOM 節點當作物件data的鍵, 但是由於物件只接受字串作為鍵名, 所以element被自動轉為字串[object HTMLpElement]。


為了解決這個問題, ES6 提供了 Map 資料結構。 它類似於對象, 也是鍵值對的集合, 但是“ 鍵” 的範圍不限於字串, 各種類型的值( 包括對象) 都可以當作鍵。 也就是說, Object 結構提供了「 字串— 值」 的對應, Map 結構提供了「 值— 值」 的對應, 是一種更完善的 Hash 結構實作。 如果你需要「 鍵值對」 的資料結構, Map 比 Object 更適合。



var m = new Map(); 
var o = { 
 p: 'Hello World' 
}; 
m.set(o, 'content') 
m.get(o) // "content" 
m.has(o) // true 
m.delete(o) // true 
m.has(o) // false
登入後複製


上面程式碼使用set方法,將物件o當作m的一個鍵, 然後又使用get方法讀取這個鍵, 接著使用

delete方法刪除了這個鍵。 作為
建構子, Map 也可以接受一個陣列作為參數。 此陣列的成員是一個個表示鍵值對的陣列。


var map = new Map([ 
 ['name', ' 张三 '], 
 ['title', 'Author'] 
]); 
map.size // 2 
map.has('name') // true 
map.get('name') // " 张三 " 
map.has('title') // true 
map.get('title') // "Author"
登入後複製


上面程式碼在新 Map 實例時,就指定了兩個鍵name和title。


Map 建構子接受陣列作為參數, 實際上執行的是下面的演算法。


var items = [ 
 ['name', ' 张三 '], 
 ['title', 'Author'] 
]; 
var map = new Map(); 
items.forEach(([key, value]) => map.set(key, value));
登入後複製


下面的範例中, 字串true和布林值true是兩個不同的鍵。



var m = new Map([ 
 [true, 'foo'], 
 ['true', 'bar'] 
]); 
m.get(true) // 'foo' 
m.get('true') // 'bar'
登入後複製


如果對同一個鍵多次賦值, 後面的值會覆寫前面的值。


let map = new Map(); 
map 
 .set(1, 'aaa') 
 .set(1, 'bbb'); 
map.get(1) // "bbb"
登入後複製


上面程式碼對鍵1連續賦值兩次, 後一次的值會覆寫前一次的值。


如果讀取一個未知的鍵,則傳回undefined。


new Map().get('asfddfsasadf') 
 // undefined
登入後複製


注意, 只有同一個物件的引用, Map 結構才會將其視為同一個鍵。 這一點要非常小心。



var map = new Map(); 
map.set(['a'], 555); 
map.get(['a']) // undefined
登入後複製


上面程式碼的set和get方法,表面是針對同一個鍵, 但實際上這是兩個值, 記憶體位址是不一樣的, 因此get方法無法讀取鍵,傳回undefined。


同理, 同樣的值的兩個實例, 在 Map 結構中被視為兩個鍵。


var map = new Map(); 
var k1 = ['a']; 
var k2 = ['a']; 
map 
 .set(k1, 111) 
 .set(k2, 222); 
map.get(k1) // 111 
map.get(k2) // 222
登入後複製


上面程式碼中,變數k1和k2的值是一樣的, 但是它們在Map 結構中被視為兩個鍵。


由上可知, Map 的鍵其實是跟記憶體位址綁定的, 只要記憶體位址不一樣, 就視為兩個鍵。 這就解決了同名屬性碰撞( clash) 的問題, 我們擴充別人的函式庫的時候, 如果使用物件作為鍵名, 就不用擔心自己的屬性與原作者的屬性同名。


如果Map 的鍵是一個簡單類型的值( 數字、 字串、 布林值), 則只要兩個值嚴格相等, Map 將其視為一個鍵, 包括0和- 0 。 另外, 雖然NaN不嚴格相等於自身, 但 Map 將其視為同一個鍵。



let map = new Map(); 
map.set(NaN, 123); 
map.get(NaN) // 123 
map.set(-0, 123); 
map.get(+0) // 123
登入後複製


以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持PHP中文網。


相關推薦:

#ie8 不支援javascript map 方法

JavaScript mapreduce工作原理簡析_基礎知識

#基於javascript 明確轉換與隱含轉換(詳解)_javascript技巧#

以上是淺談es6 javascript的map資料結構_javascript技巧的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

建議:優秀JS開源人臉偵測辨識項目 建議:優秀JS開源人臉偵測辨識項目 Apr 03, 2024 am 11:55 AM

人臉偵測辨識技術已經是一個比較成熟且應用廣泛的技術。而目前最廣泛的網路應用語言非JS莫屬,在Web前端實現人臉偵測辨識相比後端的人臉辨識有優勢也有弱勢。優點包括減少網路互動、即時識別,大大縮短了使用者等待時間,提高了使用者體驗;弱勢是:受到模型大小限制,其中準確率也有限。如何在web端使用js實現人臉偵測呢?為了實現Web端人臉識別,需要熟悉相關的程式語言和技術,如JavaScript、HTML、CSS、WebRTC等。同時也需要掌握相關的電腦視覺和人工智慧技術。值得注意的是,由於Web端的計

使用Java函數比較進行複雜資料結構比較 使用Java函數比較進行複雜資料結構比較 Apr 19, 2024 pm 10:24 PM

Java中比較複雜資料結構時,使用Comparator提供靈活的比較機制。具體步驟包括:定義比較器類,重寫compare方法定義比較邏輯。建立比較器實例。使用Collections.sort方法,傳入集合和比較器實例。

Java資料結構與演算法:深入詳解 Java資料結構與演算法:深入詳解 May 08, 2024 pm 10:12 PM

資料結構與演算法是Java開發的基礎,本文深入探討Java中的關鍵資料結構(如陣列、鍊錶、樹等)和演算法(如排序、搜尋、圖演算法等)。這些結構透過實戰案例進行說明,包括使用陣列儲存分數、使用鍊錶管理購物清單、使用堆疊實現遞歸、使用佇列同步執行緒以及使用樹和雜湊表進行快速搜尋和身份驗證等。理解這些概念可以編寫高效且可維護的Java程式碼。

js和vue的關係 js和vue的關係 Mar 11, 2024 pm 05:21 PM

js和vue的關係:1、JS作為Web開發基石;2、Vue.js作為前端框架的崛起;3、JS與Vue的互補關係;4、JS與Vue的實踐應用。

深入了解Go語言中的引用類型 深入了解Go語言中的引用類型 Feb 21, 2024 pm 11:36 PM

引用類型在Go語言中是一種特殊的資料類型,它們的值並非直接儲存資料本身,而是儲存資料的位址。在Go語言中,引用型別包括slices、maps、channels和指標。深入了解引用類型對於理解Go語言的記憶體管理和資料傳遞方式至關重要。本文將結合具體的程式碼範例,介紹Go語言中引用類型的特點和使用方法。 1.切片(Slices)切片是Go語言中最常用的引用類型之一

PHP資料結構:AVL樹的平衡之道,維持高效有序的資料結構 PHP資料結構:AVL樹的平衡之道,維持高效有序的資料結構 Jun 03, 2024 am 09:58 AM

AVL樹是一種平衡二元搜尋樹,確保快速且有效率的資料操作。為了實現平衡,它執行左旋和右旋操作,調整違反平衡的子樹。 AVL樹利用高度平衡,確保樹的高度相對於節點數始終較小,從而實現對數時間複雜度(O(logn))的查找操作,即使在大型資料集上也能保持資料結構的效率。

Java集合框架全解析:解剖資料結構,揭秘高效率儲存之道 Java集合框架全解析:解剖資料結構,揭秘高效率儲存之道 Feb 23, 2024 am 10:49 AM

Java集合框架概述Java集合框架是Java程式語言的重要組成部分,它提供了一系列可以儲存和管理資料的容器類別庫。這些容器類別庫具有不同的資料結構,可以滿足不同場景下的資料儲存和處理需求。集合框架的優點在於它提供了統一的接口,使得開發人員可以使用相同的方式來操作不同的容器類別庫,從而降低了開發難度。 Java集合框架的資料結構Java集合框架中包含多種資料結構,每種資料結構都有其獨特的特性和適用場景。以下是幾種常見的Java集合框架資料結構:1.List:List是一個有序的集合,它允許元素重複。 Li

JS 的 AI 時代來了! JS 的 AI 時代來了! Apr 08, 2024 am 09:10 AM

JS-Torch簡介JS-Torch是一種深度學習JavaScript函式庫,其語法與PyTorch非常相似。它包含一個功能齊全的張量物件(可與追蹤梯度),深度學習層和函數,以及一個自動微分引擎。 JS-Torch適用於在JavaScript中進行深度學習研究,並提供了許多方便的工具和函數來加速深度學習開發。圖片PyTorch是一個開源的深度學習框架,由Meta的研究團隊開發和維護。它提供了豐富的工具和函式庫,用於建立和訓練神經網路模型。 PyTorch的設計理念是簡單和靈活,易於使用,它的動態計算圖特性使

See all articles