bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

javascript的集合類型有哪些及怎么用

這篇文章主要介紹了javascript的集合類型有哪些及怎么用的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇javascript的集合類型有哪些及怎么用文章都會有所收獲,下面我們一起來看看吧。

創新互聯建站致力于互聯網網站建設與網站營銷,提供成都網站制作、成都網站設計、網站開發、seo優化、網站排名、互聯網營銷、微信平臺小程序開發、公眾號商城、等建站開發,創新互聯建站網站建設策劃專家,為不同類型的客戶提供良好的互聯網應用定制解決方案,幫助客戶在新的全球化互聯網環境中保持優勢。

集合類型有3種:1、map類型, Map集合中存儲的是鍵值對,鍵不能重復,值可以重復;2、Set類型,Set中存放的對象是無序,不能重復的,集合中的對象不按特定的方式排序;3、List類型,List中存放的對象是有序,可重復的,其查詢速度。

本教程操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。

javascript的集合類型有3種:set(集)、list(列表)和map(映射)。

1、Map(鍵值對、鍵唯一、值不唯一) :

Map是一組鍵值對的結構,具有極快的查找速度。通過傳入數組的數組來建立。通過調用 .set(key,value) 來添加新的元素。

var m = new Map([['Michael', 95], ['Bob', 75], ['Tracy', 85]]);
m.get('Michael'); // 95
m.set('Adam', 67); // 添加新的key-value

舉個例子,假設要根據同學的名字查找對應的成績,如果用Array實現,需要兩個Array:

var names = ['Michael', 'Bob', 'Tracy'];
var scores = [95, 75, 85];

給定一個名字,要查找對應的成績,就先要在 names 中找到對應的位置,再從 scores 取出對應的成績,Array越長,耗時越長。

如果用Map實現,只需要一個“名字”-“成績”的對照表,直接根據名字查找成績,無論這個表有多大,查找速度都不會變慢。

用 JavaScript 寫一個 Map 如下:

var m = new Map([['Michael', 95], ['Bob', 75], ['Tracy', 85]]);
m.get('Michael'); // 95

初始化 Map 需要一個二維數組,或者直接初始化一個空 Map。

Map 具有以下方法:

var m = new Map(); // 空Map
m.set('Adam', 67); // 添加新的key-value
m.set('Bob', 59);
m.has('Adam'); // 是否存在key 'Adam': true
m.get('Adam'); // 67
m.delete('Adam'); // 刪除key 'Adam'
m.get('Adam'); // undefined

由于一個 key 只能對應一個 value,所以,多次對一個 key 放入 value,后面的值會把前面的值沖掉:

var m = new Map();
m.set('Adam', 67);
m.set('Adam', 88);
m.get('Adam'); // 88

1)屬性和方法

定義:鍵/值對的集合。

語法:mapObj = new Map()

備注:集合中的鍵和值可以是任何類型。如果使用現有密鑰向集合添加值,則新值會替換舊值。

Map 對象屬性描述
構造函數指定創建映射的函數
Prototype — 原型為映射返回對原型的引用
構造函數返回映射中的元素數
Map 對象方法描述
clear從映射中移除所有元素
delete從映射中移除指定的元素
forEach對映射中的每個元素執行指定操作
get返回映射中的指定元素
has如果映射包含指定元素,則返回 true
toString返回映射的字符串表示形式
set添加一個新建元素到映射
valueOf返回指定對象的原始值
// 如何將成員添加到 Map,然后檢索它們
var m = new Map();
m.set(1, "black");
m.set(2, "red");
m.set("colors", 2);
m.set({x:1}, 3);

m.forEach(function (item, key, mapObj) {
    document.write(item.toString() + "<br />");
});

document.write("<br />");
document.write(m.get(2));

// Output:
// black
// red
// 2
// 3
//
// red

2、Set(無序、不能重復):

Set和Map類似,也是一組key的集合,但不存儲value。由于key不能重復,所以,在Set中,沒有重復的key。

Set里存放的對象是無序,不能重復的,集合中的對象不按特定的方式排序,只是簡單地把對象加入集合中。

1)創建Set

Set 本身是一個構造函數,調用構造函數用來生成 Set 數據結構。

關鍵詞 標識符 = new Set();

var s1 = new Set(); // 空Set
var s2 = new Set([1, 2, 3]); // 含1, 2, 3

Set 函數可以接受一個數組(或類似數組的對象)作為參數,用來進行數據初始化。

let i = new Set([1, 2, 3, 4, 4]);  //會得到  set{1, 2, 3, 4,}

注:如果初始化時給的值有重復的,會自動去除。集合并沒有字面量聲明方式。

2)Set的屬性

常用的屬性就一個:size   返回 Set 實例的成員總數。

let s = new Set([1, 2, 3]);
console.log( s.size ); // 3

3)Set的方法

Set 實例的方法分為兩大類:操作方法(用于數據操作)和遍歷方法(用于遍歷數據)。

操作方法:

  • add(value)    添加數據,并返回新的 Set 結構

  • delete(value)   刪除數據,返回一個布爾值,表示是否刪除成功

  • has(value)    查看是否存在某個數據,返回一個布爾值

  • clear()      清除所有數據,沒有返回值

let set = new Set([1, 2, 3, 4, 4]);
// 添加數據 5
let addSet = set.add(5);
console.log(addSet); // Set(5) {1, 2, 3, 4, 5}
// 刪除數據 4s
let delSet = set.delete(4);
console.log(delSet); // true
// 查看是否存在數據 4
let hasSet = set.has(4);
console.log(hasSet); // false
// 清除所有數據
set.clear();
console.log(set); // Set(0) {}

遍歷方法:

Set 提供了三個遍歷器生成函數和一個遍歷方法。

  • keys()     返回一個鍵名的遍歷器

  • values()    返回一個鍵值的遍歷器

  • entries()    返回一個鍵值對的遍歷器

  • forEach()   使用回調函數遍歷每個成員

let color = new Set(["red", "green", "blue"]);
for(let item of color.keys()){
 console.log(item);
}
// red
// green
// blue
for(let item of color.values()){
 console.log(item);
}
// red
// green
// blue
for(let item of color.entries()){
 console.log(item);
}
// ["red", "red"]
// ["green", "green"]
// ["blue", "blue"]
color.forEach((item) => {
 console.log(item)
})
// red
// green
// blue

3、List(有序、可重復) :

列表是一組有序的數據,每個列表中的數據項稱為元素。

List里存放的對象是有序的,同時也是可以重復的,List關注的是索引,擁有一系列和索引相關的方法,查詢速度快。因為往list集合里插入或刪除數據時,會伴隨著后面數據的移動,所有插入刪除數據速度慢。

列表擁有描述元素位置的屬性,列表有前有后(front和end)。

使用next()方法可以從當前元素移動到下一個元素,使用next() 可以從當前元素移動到下一個元素,使用prev()方法可以移動到當前元素的前一個元素,還可以使用moveTo(n)方法直接移動到指定位置

1)List的方法:

  • 定義的屬性有:

    • listSize : 列表的元素個數

    • pos: 列表的當前位置

  • 定義的方法有:

    • getElement(): 返回當前位置的元素

    • insert(): 在現有元素后插入新元素

    • append(): 在列表的尾部添加新元素

    • remove(): 從列表中刪除元素

    • length(): 返回列表中元素的個數

    • clear(): 清空列表

    • contains(): 判斷元素是否存在列表中

  • 移動元素:

    • front(): 將列表的當前位置移動到第一個元素

    • end(): 將列表的當前位置移動到最后一個元素

    • prev(): 將當前位置后移一位

    • next(): 將當前位置前移一位

    • currPos(): 返回列表的當前位置

    • moveTo(): 將當前位置移動到指定位置

2)List的實現

  • 使用數組實現一個列表,并初始化屬性值

function List() {
    this.listSize = 0; //記錄列表元素的個數
    this.pos = 0; //記錄列表的位置
    this.dataStore = []; //存儲列表元素
}
  • append(element) 添加元素

給列表尾部添加新元素的方法與棧的壓棧方法一樣;

將記錄元素個數的listSize加1,從而獲取到存儲元素的位置;再將元素添加到這個位置;

function append(element) {
    //讓列表的長度加1,再將元素填充到新增的位置
    this.dataStore[this.listSize++] = element;
}
  • find(element) 查找元素

首先遍歷列表,如果要查找的元素存在列表中,則返回該元素的位置,未找到則返回-1

function find(element) {
    //遍歷列表
    for (let i = 0; i < this.dataStore.length; ++i) {
        //判斷列表中是否有該元素,存在則返回索引i
        if (this.dataStore[i] == element) {
            return i;
        };
    };
    //不存在返回-1
    return -1;
};
  • remove(element) 刪除元素

先調用find方法,查找元素的位置,如果存在返回true,不存在則會返回false;

如果存在,使用js數組操作方法splice刪除當前元素,splice方法接收兩個參數,即要刪除的元素的索引和要刪除的個數;

刪除元素后,要將列表的長度減1;

function remove(element) {
    //調用定義的find方法查找元素
    let fountAt = this.find(element);
    //元素存在
    if (fountAt > -1) {
        //刪除索引對應的值
        this.dataStore.splice(fountAt, 1);
        //列表少了一個元素,減1
        --this.listSize;
        //操作成功返回true
        return true;
    };
    //找不到元素返回false
    return false;
};
  • length() 查詢列表中有多少元素

該方法返回列表中的元素,直接返回listSize的值

function length() {
    return this.listSize;
}
  • insert(element, after) 向列表中插入元素

該方法是將目標元素插入到指定元素的后面,它接收兩個參數,即目標元素element和指定元素after;

實現:先使用定義的find方法找到after的位置,然后使用splice方法在該位置的后一位插入目標元素;

splice方法傳入三個參數,目標值的位置,要刪除的數量,要插入的值(第二個參數為0表示刪除0個,不刪除元素);

操作成功返回true, 未找到指定元素則返回false

function insert(element, after) {
    let insertPos = this.find(after);
    if (insertPos > -1) {
        this.dataStore.splice(insertPos + 1, 0, element);
        ++this.listSize;
        return true;
    };
    return false;
}
  • clear() 清空列表

刪除列表,初始化數據

function clear() {
    delete this.dataStore;
    this.dataStore = [];
    this.listSize = 0;
    this.pos = 0;
};
  • contains(element) 判斷元素是否存在列表中

與find方法類似,也可直接使用find方法查找,找到返回true,不存在返回false

function contains(element) {
	for (let i = 0; i < this.dataStore.length; ++i) {
        if (this.dataStore[i] == element) {
            return true;
        };
    };
    return false;
};
  • 迭代器:移動列表中的元素

創建手動迭代列表的一些方法,可以不用關心數據的內部存儲方法,以實現對列表的遍歷。

//移動到最前面
function front() {
    this.pos = 0;
};
//移動到最后面
function end() {
    this.pos = this.listSize - 1;
};
//往后移一位
function prev() {
    if (this.pos > 0) {
        --this.pos;
    };
};
//往前移一位
function next() {
    if (this.pos < this.listSize-1) {
        ++this.pos;
    };
};
//返回列表當前的位置
function currPos() {
    return this.pos;
};
//移動到指定的位置
function moveTo(position) {
    this.pos = position;
};
//返回當前元素的位置
function getElement() {
    return this.dataStore[this.pos];
};

關于“javascript的集合類型有哪些及怎么用”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“javascript的集合類型有哪些及怎么用”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注創新互聯行業資訊頻道。

網站題目:javascript的集合類型有哪些及怎么用
URL標題:http://vcdvsql.cn/article18/pegidp.html

成都網站建設公司_創新互聯,為您提供網站策劃電子商務靜態網站關鍵詞優化搜索引擎優化響應式網站

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

綿陽服務器托管