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

JS中數(shù)組Array的用法示例介紹

 更新時(shí)間:2014年02月20日 09:43:18   作者:  
這篇文章主要介紹了JS中數(shù)組Array的用法,需要的朋友可以參考下
new Array()
new Array(len)
new Array([item0,[item1,[item2,...]]]
使用數(shù)組對(duì)象的方法:
var objArray=new Array();
objArray.concact([item1[,item2[,....]]]-------------------將參數(shù)列表連接到objArray的后面形成一個(gè)新的數(shù)組并返回,原有數(shù)組不受影響。如:var arr=["a","b","c"];
arr.concact("d","e");
將返回包括從"a"到"e"字母元素的數(shù)組。而arr本身不受影響。
objArray.join(separator)-----------------以separator指定的字符作為分割符,將數(shù)組轉(zhuǎn)換為字符串,當(dāng)seperator 為逗號(hào)時(shí),其作用和toString()相同。
objArray.pop()---------通俗的講,就是彈出數(shù)組的最后一個(gè)元素。結(jié)合下面的push方法,使得將數(shù)組作為棧來(lái)使用成為可能。pop方法返回?cái)?shù)組最后一個(gè)元素的值,并將length屬性減1,即返回后立即丟失最后一個(gè)元素。
objArray.push([value1[,value2[,....]]])-------------將參數(shù)添加到數(shù)組的結(jié)尾。如:[1,2,3, 4].push("a","b")將得到[1,2,3,4,"a","b"]
objArray.reverse()將數(shù)組中的元素反轉(zhuǎn)排列。如:[1,2,3].reverse()將得到[3,2,1],這個(gè)操作是在原有數(shù)組上經(jīng)行操作,同時(shí)也返回?cái)?shù)組本身
objArray.shift()-----------移去數(shù)組的第一個(gè)元素,并返回這個(gè)元素的值。這個(gè)方法的性質(zhì)和pop方法很類似,pop方法是移去最后一個(gè)元素。
objArray.slice(start,end)----------- 返回?cái)?shù)組對(duì)象的一個(gè)子集,索引從start開(kāi)始(包括 start),到end結(jié)束(不包括end),原有數(shù)組不受影響。如:[1,2,3,4,5,6].slice(1,4)將得到[2,3,4]。當(dāng) start或者end為負(fù)數(shù)時(shí),則使用他們加上length后地值。如:[1,2,3,4,5,6].slice(-4,-1)將得到[3,4,5]。如果end小于等于start,將返回空數(shù)組。
objArray.sort(comparefn)------- 根據(jù)comparefn定義的大小比較函數(shù),對(duì)一個(gè)數(shù)組進(jìn)行排序。函數(shù)comparefn必須接受兩個(gè)參數(shù)element1,element2,如果需要需要element1排在element2之前,應(yīng)該返回一個(gè)負(fù)數(shù);如果需要element1排在element2之后,應(yīng)該返回一個(gè)正數(shù),如果兩個(gè)數(shù)平等對(duì)待(即保持原有順序)則返回0。當(dāng)省略comparefn時(shí),則元素按照字典順序排列。如:對(duì)定義的比較函數(shù)cmp: function cmp(e1,e2){return e1-e2;}則[3,4,2,7].sort(cmp)將得到[2,3,4,7].
objArray.splice(start,deleteCount[,item1,item2[,...]]]) 這是一個(gè)復(fù)雜的函數(shù),用于完成數(shù)組元素的刪除 取代和插入操作。其中,start參數(shù)表示要進(jìn)行操作的索引位置,deleteCount指從start開(kāi)始要?jiǎng)h除的元素的元素個(gè)數(shù)(包括了start位置),如果deleteCount省略,則表示從start開(kāi)始要?jiǎng)h除數(shù)組的剩余部分。[,item1[,item2[,...]]]則表示可選的插入到start之前的元素列表。如:
var arr=[0,1,2,3,4,5,6];
arr.splice(1,1);
document.write(arr);//顯示“0,2,3,4,5,6”
arr=[0,1,2,3,4,5,6];
arr.splice(0,0,"a","b");
document.write(arr);//顯示“a,b,0,1,2,3,4,5,6"
arr=[0,1,2,3,4,5,6];
arr.splice(3,2,"c","d");
document.write(arr);//顯示"0,1,2,c,d,5,6"
objArray.unshift(item1[,item2[,...]]])------------------- 將參數(shù)列表插入到數(shù)組的開(kāi)頭。其性質(zhì)和push方法類型,但push方法是將元素添加到數(shù)組的結(jié)尾。如: [1,2,3,4].unshift("a","b")將得到["a","b",1,2,3,4]。

js數(shù)組元素的添加和刪除一直比較迷惑,今天終于找到詳細(xì)說(shuō)明的資料了,先給個(gè)我測(cè)試的代碼^-^
var arr = new Array();
arr[0] = "aaa";
arr[1] = "bbb";
arr[2] = "ccc";
//alert(arr.length);//3
arr.pop();
//alert(arr.length);//2
//alert(arr[arr.length-1]);//bbb
arr.pop();
//alert(arr[arr.length-1]);//aaa
//alert(arr.length);//1

var arr2 = new Array();
//alert(arr2.length);//0
arr2[0] = "aaa";
arr2[1] = "bbb";
//alert(arr2.length);//2
arr2.pop();
//alert(arr2.length);//1
arr2 = arr2.slice(0,arr2.length-1);
//alert(arr2.length);//0
arr2[0] = "aaa";
arr2[1] = "bbb";
arr2[2] = "ccc";
arr2 = arr2.slice(0,1);
alert(arr2.length);//1
alert(arr2[0]);//aaa
alert(arr2[1]);//undefined

shift:刪除原數(shù)組第一項(xiàng),并返回刪除元素的值;如果數(shù)組為空則返回undefined
var a = [1,2,3,4,5];
var b = a.shift(); //a:[2,3,4,5] b:1

unshift:將參數(shù)添加到原數(shù)組開(kāi)頭,并返回?cái)?shù)組的長(zhǎng)度
var a = [1,2,3,4,5];
var b = a.unshift(-2,-1); //a:[-2,-1,1,2,3,4,5] b:7
注:在IE6.0下測(cè)試返回值總為undefined,F(xiàn)F2.0下測(cè)試返回值為7,所以這個(gè)方法的返回值不可靠,需要用返回值時(shí)可用splice代替本方法來(lái)使用。

pop:刪除原數(shù)組最后一項(xiàng),并返回刪除元素的值;如果數(shù)組為空則返回undefined
var a = [1,2,3,4,5];
var b = a.pop(); //a:[1,2,3,4] b:5//不用返回的話直接調(diào)用就可以了

push:將參數(shù)添加到原數(shù)組末尾,并返回?cái)?shù)組的長(zhǎng)度
var a = [1,2,3,4,5];
var b = a.push(6,7); //a:[1,2,3,4,5,6,7] b:7

concat:返回一個(gè)新數(shù)組,是將參數(shù)添加到原數(shù)組中構(gòu)成的
var a = [1,2,3,4,5];
var b = a.concat(6,7); //a:[1,2,3,4,5] b:[1,2,3,4,5,6,7]

splice(start,deleteCount,val1,val2,...):從start位置開(kāi)始刪除deleteCount項(xiàng),并從該位置起插入val1,val2,...

在清空數(shù)組時(shí),只需傳遞startIndex。

如果不刪除所有元素,再傳遞deleteCount參數(shù)。

splice還具有先刪除后添加的功能,即先刪除幾個(gè)元素,然后在刪除的位置再添加若干元素,刪除與添加的元素的個(gè)數(shù)沒(méi)有必須相等,這時(shí)侯deleteCount也是要用到的。
var a = [1,2,3,4,5];
var b = a.splice(2,2,7,8,9); //a:[1,2,7,8,9,5] b:[3,4]
var b = a.splice(0,1); //同shift
a.splice(0,0,-2,-1); var b = a.length;//同unshift
var b = a.splice(a.length-1,1);//同pop
a.splice(a.length,0,6,7); var b = a.length; //同push

reverse:將數(shù)組反序
var a = [1,2,3,4,5];
var b = a.reverse(); //a:[5,4,3,2,1] b:[5,4,3,2,1]

sort(orderfunction):按指定的參數(shù)對(duì)數(shù)組進(jìn)行排序
var a = [1,2,3,4,5];
var b = a.sort(); //a:[1,2,3,4,5] b:[1,2,3,4,5]

slice(start,end):返回從原數(shù)組中指定開(kāi)始下標(biāo)到結(jié)束下標(biāo)之間的項(xiàng)組成的新數(shù)組
var a = [1,2,3,4,5];
var b = a.slice(2,5); //a:[1,2,3,4,5] b:[3,4,5]

join(separator):將數(shù)組的元素組起一個(gè)字符串,以separator為分隔符,省略的話則用默認(rèn)用逗號(hào)為分隔符
var a = [1,2,3,4,5];
var b = a.join("|"); //a:[1,2,3,4,5] b:"1|2|3|4|5"

再給個(gè)利用數(shù)組模擬javaStringBuffer處理字符串的方法:
復(fù)制代碼 代碼如下:

/**
* 字符串處理函數(shù)
*/
function StringBuffer() {
var arr = new Array;
this.append = function(str) {
arr[arr.length] = str;
};

this.toString = function() {
return arr.join("");//把a(bǔ)ppend進(jìn)來(lái)的數(shù)組ping成一個(gè)字符串
};
}

今天在應(yīng)用中突然發(fā)現(xiàn)join是一種把數(shù)組轉(zhuǎn)換成字符串的好方法,故封裝成對(duì)象使用了:
復(fù)制代碼 代碼如下:

/**
*把數(shù)組轉(zhuǎn)換成特定符號(hào)分割的字符串
*/
function arrayToString(arr,separator) {
if(!separator) separator = "";//separator為null則默認(rèn)為空
return arr.join(separator);
}

/**
* 查找數(shù)組包含的字符串
*/
function arrayFindString(arr,string) {
var str = arr.join("");
return str.indexOf(string);
}

相關(guān)文章

  • JavaScript實(shí)現(xiàn)左右點(diǎn)擊切換圖片

    JavaScript實(shí)現(xiàn)左右點(diǎn)擊切換圖片

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)簡(jiǎn)易左右點(diǎn)擊切換圖片,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • 微信小程序與axios組成網(wǎng)絡(luò)層封裝過(guò)程詳解

    微信小程序與axios組成網(wǎng)絡(luò)層封裝過(guò)程詳解

    小程序在網(wǎng)絡(luò)層提供的API是能夠完成一個(gè)程序與服務(wù)端交互的完整鏈路,但需要大量的定制化代碼,才能實(shí)現(xiàn)請(qǐng)求攔截和響應(yīng)攔截,不太符合大多數(shù)開(kāi)發(fā)者的使用習(xí)慣,對(duì)于前端開(kāi)發(fā)者來(lái)說(shuō),網(wǎng)絡(luò)層還得是axios
    2023-02-02
  • JS命令模式例子之菜單程序

    JS命令模式例子之菜單程序

    這篇文章主要為大家詳細(xì)介紹了JS命令模式例子之菜單程序,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • 一些在TypeScript上費(fèi)過(guò)時(shí)間的地方總結(jié)

    一些在TypeScript上費(fèi)過(guò)時(shí)間的地方總結(jié)

    這篇文章主要給大家介紹了關(guān)于一些在ts上費(fèi)過(guò)時(shí)間的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2021-11-11
  • javascript 作用于作用域鏈的詳解

    javascript 作用于作用域鏈的詳解

    這篇文章主要介紹了javascript 作用于作用域鏈的詳解的相關(guān)資料,希望通過(guò)本文能幫助到大家,理解掌握這部分內(nèi)容,需要的朋友可以參考下
    2017-09-09
  • JavaScript使用Replace進(jìn)行字符串替換的方法

    JavaScript使用Replace進(jìn)行字符串替換的方法

    這篇文章主要介紹了JavaScript使用Replace進(jìn)行字符串替換的方法,涉及Replace進(jìn)行一次替換與全部替換的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-04-04
  • javascript數(shù)組組合成字符串的腳本

    javascript數(shù)組組合成字符串的腳本

    javascript數(shù)組組合成字符串的腳本...
    2007-11-11
  • JS Canvas接口和動(dòng)畫(huà)效果大全

    JS Canvas接口和動(dòng)畫(huà)效果大全

    這篇文章主要介紹了JS Canvas接口和動(dòng)畫(huà)效果大全,對(duì)Canvas感興趣的同學(xué),可以參考下
    2021-04-04
  • 解析ES6中的解構(gòu)賦值(數(shù)組,對(duì)象,嵌套,默認(rèn)值)

    解析ES6中的解構(gòu)賦值(數(shù)組,對(duì)象,嵌套,默認(rèn)值)

    解構(gòu)賦值是一種特殊的語(yǔ)法,它使我們可以將數(shù)組或?qū)ο蟆安鸢敝烈幌盗凶兞恐?,因?yàn)橛袝r(shí)這樣更方便,接下來(lái)通過(guò)本文給大家介紹ES6中的解構(gòu)賦值(數(shù)組,對(duì)象,嵌套,默認(rèn)值),需要的朋友可以參考下
    2022-11-11
  • 微信小程序收藏功能的實(shí)現(xiàn)代碼

    微信小程序收藏功能的實(shí)現(xiàn)代碼

    這篇文章主要介紹了微信小程序收藏功能的實(shí)現(xiàn)代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-06-06

最新評(píng)論