欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript學(xué)習(xí)筆記之?dāng)?shù)組的增、刪、改、查

 更新時(shí)間:2016年03月23日 10:30:29   作者:Airen  
這篇文章主要介紹了JavaScript學(xué)習(xí)筆記之?dāng)?shù)組的增、刪、改、查的相關(guān)資料,需要的朋友可以參考下

在程序語言中數(shù)組的重要性不言而喻,JavaScript中數(shù)組也是最常使用的對(duì)象之一,數(shù)組是值的有序集合,由于弱類型的原因,JavaScript中數(shù)組十分靈活、強(qiáng)大,不像是Java等強(qiáng)類型高級(jí)語言數(shù)組只能存放同一類型或其子類型元素,JavaScript在同一個(gè)數(shù)組中可以存放多種類型的元素,而且是長(zhǎng)度也是可以動(dòng)態(tài)調(diào)整的,可以隨著數(shù)據(jù)增加或減少自動(dòng)對(duì)數(shù)組長(zhǎng)度做更改。

數(shù)組是JavaScript中常見的一個(gè)對(duì)象,它有一些經(jīng)典的操作,比如數(shù)組的增、刪、改、查。在這篇文章中主要整理這方面的相關(guān)操作方法。

增加數(shù)組項(xiàng)

首先來看如何給一個(gè)數(shù)組增加數(shù)組項(xiàng)。假設(shè)有一個(gè)數(shù)組:

var arr = [];

上面聲明了一個(gè)數(shù)組,但這個(gè)數(shù)組是一個(gè)空數(shù)組 [] ,其 length 的值為 0 。接下來我們看如何給數(shù)組 arr 增加數(shù)組項(xiàng)。最簡(jiǎn)單的方法可以通過索引值方式,給數(shù)組增加數(shù)組項(xiàng):

var arr = [];
arr[0] = 'a';
arr[1] = 'b';
arr[2] = 1;
arr[3] = 2;
console.log(arr); // ["a", "b", 1, 2]
console.log(arr.length); // 4

另外也可以通過改為數(shù)組的 length 值給數(shù)組增加數(shù)組項(xiàng),不過這種方法給數(shù)組增加的數(shù)組項(xiàng)都是 undefined :

var arr = [];
arr[0] = 'a'; // 給數(shù)組arr添加一個(gè)`a`數(shù)組項(xiàng)
arr.length = 5; // 改變數(shù)組的`length`值為`5`
console.log(arr); // ["a", undefined × 4]

雖然這種方法也給數(shù)組增加了數(shù)組項(xiàng),但相對(duì)來說都較為麻煩。其實(shí)給數(shù)組添加數(shù)組項(xiàng),沒有這么麻煩,可以通過數(shù)組提供的原生方法給數(shù)組添加數(shù)組項(xiàng)。

push()

使用 push() 方法可以給數(shù)組末尾添加一個(gè)或多個(gè)數(shù)組項(xiàng)。

var arr = [];
arr.push('a','b');
console.log(arr); // ['a','b']
unshift()

使用 push() 方法可以給數(shù)組末尾添加一個(gè)或多個(gè)數(shù)組項(xiàng),那么使用 unshift() 方法可以在數(shù)組的前面添加一個(gè)或多個(gè)數(shù)組項(xiàng):

var arr = ['a','b'];
arr.unshift(1,2);
console.log(arr); // [1, 2, "a", "b"]

除了這兩種方法之外,還可以使用 splice() 方法給數(shù)組添加數(shù)組項(xiàng):

var arr = ['a','b','c',1,2];
arr.splice(2,0,'d','c','e');
console.log(arr); // ["a", "b", "d", "c", "e", "c", 1, 2]

另外除了 splice() 方法之外還可以使用 concat() 方法可以給數(shù)組添加數(shù)組項(xiàng),只不過使用這種方法不會(huì)改變?cè)瓟?shù)組,會(huì)在原數(shù)組中創(chuàng)建一個(gè)新數(shù)組:

var arr = ['a','b','c'];
var arr2 = arr.concat('d',1,2,['e',3]);
console.log(arr); // ["a", "b", "c"]
console.log(arr2); // ["a", "b", "c", "d", 1, 2, "e", 3]

刪除數(shù)組項(xiàng)

對(duì)于數(shù)組的操作,除了增加數(shù)組項(xiàng),很多時(shí)候還需要對(duì)數(shù)組進(jìn)行刪除操作。刪除數(shù)組項(xiàng)常用的方法有 pop() 和 shift() 兩種方法。

pop()

pop() 方法可以從數(shù)組的末尾刪除一個(gè)數(shù)組項(xiàng):

var arr = ['a','b','c','d',1,2];
arr.pop();
console.log(arr); // ["a", "b", "c", "d", 1]

shift()

shift() 方法和 pop() 方法剛好相反,它可以刪除數(shù)組的第一項(xiàng):

var arr = ['a','b','c','d',1,2];
arr.shift();
console.log(arr); // ["b", "c", "d", 1, 2]

不管是 pop() 或 shift() 方法每次只能給數(shù)組刪除一個(gè)數(shù)組項(xiàng),但很多時(shí)候這樣刪除數(shù)組項(xiàng)相對(duì)來說是比較麻煩的。在數(shù)組的操作中,除了這兩種方法之外,還可以通過 slice() 和 splice() 方法來刪除數(shù)組項(xiàng)。

slice()

slice() 方法可以給一個(gè)數(shù)組中刪除多個(gè)數(shù)組項(xiàng),只不過不同的是, slice() 不會(huì)影響原數(shù)組,只是會(huì)在原數(shù)組基礎(chǔ)上創(chuàng)建一個(gè)數(shù)組副本:

var arr = [1,2,3,4,'a','b'];
var arr2 = arr.slice(2);
console.log(arr); // [1, 2, 3, 4, "a", "b"]
console.log(arr2); // [3, 4, "a", "b"]
console.log(arr3); // ["a", "b"]

splice()

splice() 方法除了能給數(shù)組添加數(shù)組項(xiàng)之外,還可以給數(shù)組刪除數(shù)組項(xiàng):

var arr = [1,2,3,4,'a','b','c'];
var arr2 = arr.splice(2,2);
console.log(arr); // [1, 2, "a", "b", "c"]
console.log(arr2); // [3, 4]

改變數(shù)組

數(shù)組中 splice() 方法是數(shù)組中一個(gè)強(qiáng)大的方法,其除了可以給數(shù)組添加數(shù)組項(xiàng)、刪除數(shù)組項(xiàng)之外,還可以改變一個(gè)數(shù)組:

var arr = [1,2,3,4,5,6];
var arr2 = arr.splice(2,3,'a','b','c');
console.log(arr); // [1, 2, "a", "b", "c", 6]
console.log(arr2); // [3, 4, 5]

數(shù)組的查詢

這里所說的數(shù)組查詢其實(shí)指的是數(shù)組的查詢提取。其使用的方法是 slice() 方法:

var arr = [1,2,3,4,5,6];
var arr2 = arr.slice(-3);
console.log(arr); // [1, 2, 3, 4, 5, 6]
console.log(arr2); // [4, 5, 6]

總結(jié)

這里簡(jiǎn)單的整理了一個(gè)數(shù)組的增、刪、改、查的相關(guān)方法。簡(jiǎn)單的總結(jié)一下:

增加數(shù)組項(xiàng)方法:除了直接改變數(shù)組項(xiàng)的值和修改數(shù)組的 length 給數(shù)組添加數(shù)組項(xiàng)方法之外,還可以使用 push() 、 unshift() 、 concat() 和 splice() 添加數(shù)組項(xiàng)

刪除數(shù)組項(xiàng)方法:刪除數(shù)組項(xiàng)方法有 pop() 、 shift() 、 slice() 和 splice() 方法

改變數(shù)組項(xiàng)方法:在數(shù)組中主要通過 splice() 方法來改變數(shù)組項(xiàng)

查詢數(shù)組項(xiàng)方法: 查詢數(shù)組項(xiàng)方法其實(shí)就是對(duì)數(shù)組做查詢提取功能,主要使用的方法是 slice() 方法

有關(guān)于 pop() 、 push() 、 shift() 和 unshift() 操作方法可以點(diǎn)擊這里;關(guān)于 concat() 、 slice() 和 splice() 方法的相關(guān)介紹可以點(diǎn)擊這里。

有關(guān)JavaScript學(xué)習(xí)筆記之?dāng)?shù)組的增、刪、改、查小編就給大家介紹到這里,希望對(duì)大家有所幫助!更多有關(guān)javascript知識(shí)請(qǐng)登陸腳本之家網(wǎng)站官網(wǎng)了解詳情!

相關(guān)文章

  • 萬物皆可柯里化的Ramda.js及傳參詳解

    萬物皆可柯里化的Ramda.js及傳參詳解

    這篇文章主要為大家介紹了萬物皆可柯里化的Ramda.js詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • 深入了解JavaScript中的垃圾回收機(jī)制

    深入了解JavaScript中的垃圾回收機(jī)制

    JavaScript中的垃圾回收機(jī)制負(fù)責(zé)自動(dòng)管理內(nèi)存,回收不再使用的對(duì)象所占用的內(nèi)存空間。本文主要介紹了JS中垃圾回收機(jī)制的相關(guān)知識(shí),需要的可以參考一下
    2023-04-04
  • JS代碼計(jì)算LocalStorage容量示例詳解

    JS代碼計(jì)算LocalStorage容量示例詳解

    這篇文章主要為大家介紹了JS代碼計(jì)算LocalStorage容量的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • 如何設(shè)置iframe高度自適應(yīng)在跨域情況下的可用方法

    如何設(shè)置iframe高度自適應(yīng)在跨域情況下的可用方法

    iframe的高度需要根據(jù)子頁面的實(shí)際高度來進(jìn)行調(diào)整,但是如果子頁面不在同一域中怎么辦?這時(shí)候腳本沒有辦法獲取到子頁面的高度,存在JavaScript跨域的問題
    2013-09-09
  • 詳解JS事件循環(huán)及宏任務(wù)微任務(wù)的原理

    詳解JS事件循環(huán)及宏任務(wù)微任務(wù)的原理

    在js中,我們一般將所有的任務(wù)都分成兩類,一種是同步任務(wù),另外一種是異步任務(wù)。而在異步任務(wù)中,又有著更加細(xì)致的分類,那就是微任務(wù)和宏任務(wù)。本文將詳細(xì)講解這二者的原理與使用,需要的可以參考一下
    2022-05-05
  • bootstrap表單按回車會(huì)自動(dòng)刷新頁面的解決辦法

    bootstrap表單按回車會(huì)自動(dòng)刷新頁面的解決辦法

    這篇文章主要介紹了bootstrap表單按回車會(huì)自動(dòng)刷新頁面的問題及解決辦法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-03-03
  • 微信小程序分享海報(bào)生成的實(shí)現(xiàn)方法

    微信小程序分享海報(bào)生成的實(shí)現(xiàn)方法

    為了吸引更多的用戶,設(shè)計(jì)好一個(gè)分享海報(bào)還是很有必要的,這篇文章主要介紹了微信小程序分享海報(bào)生成的實(shí)現(xiàn)方法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2018-12-12
  • js arguments.callee的應(yīng)用代碼

    js arguments.callee的應(yīng)用代碼

    arguments.callee的使用方法,具體大家自己測(cè)試了
    2009-05-05
  • js實(shí)現(xiàn)網(wǎng)頁五子棋進(jìn)階版

    js實(shí)現(xiàn)網(wǎng)頁五子棋進(jìn)階版

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)網(wǎng)頁五子棋進(jìn)階版,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • 微信小程序3種位置API的使用方法詳解

    微信小程序3種位置API的使用方法詳解

    這篇文章主要介紹了微信小程序3種位置API的使用方法詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-08-08

最新評(píng)論