亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解JavaScript中的Map和WeakMap

 更新時間:2023年08月31日 08:37:40   作者:編程三昧  
Map和WeakMap都是ES6中新增的數(shù)據(jù)結(jié)構(gòu),它們的主要區(qū)別在于鍵的作用域和鍵的類型,本文就通過代碼示例給大家詳細(xì)介紹了JavaScript鍵的作用域和類型,需要的朋友可以參考下

鍵的作用域

Map 的鍵的作用域是全局的,也就是說,Map 中的鍵不會被污染,也不會對其他的變量產(chǎn)生影響。而 WeakMap 的鍵的作用域是局部的,也就是說,WeakMap 中的鍵只在定義它的函數(shù)作用域內(nèi)有效,一旦函數(shù)執(zhí)行完畢,WeakMap 中的鍵就會被釋放。

鍵的類型

Map 的鍵可以是任意類型的值,包括對象、數(shù)組、函數(shù)等等。而 WeakMap 的鍵只能是對象,因為 WeakMap 是通過引用計數(shù)來管理鍵的,如果鍵不是對象,就無法計數(shù)。

下面是一個使用 Map 和 WeakMap 的示例代碼:

// 使用 Map 存儲數(shù)據(jù)
const map = new Map();
map.set("a", 1);
map.set("b", 2);
map.set("c", 3);
// 使用 WeakMap 存儲數(shù)據(jù)
const weakMap = new WeakMap();
const obj1 = {};
const obj2 = {};
weakMap.set(obj1, 1);
weakMap.set(obj2, 2);
weakMap.set(obj1, 3);
console.log(map.get("a")); // 1
console.log(map.get("b")); // 2
console.log(map.get("c")); // 3
console.log(weakMap.get(obj1)); // 3
console.log(weakMap.get(obj2)); // 2

鍵的可枚舉性

Map對象不同的是,WeakMap的鍵是不可枚舉的。不提供列出其鍵的方法。列表是否存在取決于垃圾回收器的狀態(tài),是不可預(yù)知的。

總結(jié)

如果有需要遍歷鍵值對的需求,則需要使用 Map。

到此這篇關(guān)于詳解JavaScript中的Map和WeakMap的文章就介紹到這了,更多相關(guān)JavaScript Map和WeakMap內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • ES6 Map結(jié)構(gòu)的應(yīng)用實例分析

    ES6 Map結(jié)構(gòu)的應(yīng)用實例分析

    這篇文章主要介紹了ES6 Map結(jié)構(gòu)的應(yīng)用,結(jié)合實例形式分析了ES6中map鍵值對hash結(jié)構(gòu)相關(guān)定義、獲取、輸出、遍歷等相關(guān)操作技巧,需要的朋友可以參考下
    2019-06-06
  • JavaScript實現(xiàn)定時隱藏與顯示圖片的方法

    JavaScript實現(xiàn)定時隱藏與顯示圖片的方法

    這篇文章主要介紹了JavaScript實現(xiàn)定時隱藏與顯示圖片的方法,可實現(xiàn)javascript定時關(guān)閉圖片的功能,涉及javascript針對頁面元素屬性定時操作的相關(guān)技巧,需要的朋友可以參考下
    2015-08-08
  • 關(guān)于JavaScript中異步/等待的用法與理解

    關(guān)于JavaScript中異步/等待的用法與理解

    這篇文章主要給大家介紹了關(guān)于JavaScript中異步/等待的用法與理解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • JS動態(tài)增加刪除UL節(jié)點LI及相關(guān)內(nèi)容示例

    JS動態(tài)增加刪除UL節(jié)點LI及相關(guān)內(nèi)容示例

    這篇文章主要介紹了JS如何動態(tài)增加刪除UL節(jié)點LI及相關(guān)內(nèi)容,需要的朋友可以參考下
    2014-05-05
  • JavaScript簡單實現(xiàn)合并兩個Json對象的方法示例

    JavaScript簡單實現(xiàn)合并兩個Json對象的方法示例

    這篇文章主要介紹了JavaScript簡單實現(xiàn)合并兩個Json對象的方法,結(jié)合實例形式分析了json對象的遍歷、添加實現(xiàn)合并的相關(guān)操作技巧,需要的朋友可以參考下
    2017-10-10
  • JavaScript時間復(fù)雜度和空間復(fù)雜度

    JavaScript時間復(fù)雜度和空間復(fù)雜度

    這篇文章主要介紹了JavaScript時間復(fù)雜度和空間復(fù)雜度,時間復(fù)雜度和空間復(fù)雜度是衡量一個算法是否優(yōu)秀的標(biāo)準(zhǔn),通常我們比較兩個算法時會用預(yù)先估算和事后統(tǒng)計,下文詳細(xì)介紹,需要的朋友可以參考一下
    2022-07-07
  • 利用jsonp跨域調(diào)用百度js實現(xiàn)搜索框智能提示

    利用jsonp跨域調(diào)用百度js實現(xiàn)搜索框智能提示

    這篇文章主要為大家詳細(xì)介紹了使用jsonp跨域調(diào)用百度js實現(xiàn)搜索框智能提示,感興趣的小伙伴們可以參考一下
    2016-08-08
  • javascript object array方法使用詳解

    javascript object array方法使用詳解

    在javascript開發(fā)中經(jīng)常會使用到array中方法,本文將對其一一詳細(xì)介紹,需要了解的朋友可以參考下
    2012-12-12
  • js制作輪播圖效果

    js制作輪播圖效果

    這篇文章主要為大家詳細(xì)介紹了js制作輪播圖效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • JS生態(tài)系統(tǒng)加速eslint解析器使用實例探索

    JS生態(tài)系統(tǒng)加速eslint解析器使用實例探索

    這篇文章主要為大家介紹了JS生態(tài)系統(tǒng)加速之eslint解析器使用實例探索,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2024-01-01

最新評論