js中的操作數(shù)組~

1、數(shù)組的創(chuàng)建

var arrObj = new Array();
var arrObj = new Array([size]);
var arrObj = new;
Array([element0[element1,elsement2]]

雖然第二種方法創(chuàng)建數(shù)組指定了長度 ,但實際上所有情況下數(shù)組都是變長的膏燕,也就是說即使制定了長度5,仍然可以將元素存儲在規(guī)定長度以外的悟民。注意:這時長度會隨之改變

2坝辫、數(shù)組的元素訪問

var arrValue = arrObj [ i ] ; //獲取數(shù)組的元素值 arr[ i ] = "這是新值"; //給數(shù)組元素賦予新的值

3、數(shù)組元素的添加

a.arrObj.push()
將一個或多個元素添加到數(shù)組的結(jié)尾

b.arrObj.unshift()
將一個或多個元素添加到數(shù)組的開始

c.``arrObj.splice()`
將一個或多個元素插入到數(shù)組的指定位置射亏,返回刪除的數(shù)組

4近忙、數(shù)組元素的刪除

a.arrObj.pop();
移出最后一個元素并返回該元素的值
b.arrObj.shift();
移出最前一個元素并返回該元素的值竭业,數(shù)組中元素自動前移
c.arrObj.splice(deletePos,deleteCount);
刪除從指定位置deketePos開始 的指定數(shù)量deleteCount的元素,數(shù)組形式返回所移出的元素及舍。

5永品、數(shù)組的截取和合并

a.arrObj.slice(start,[end]);
已數(shù)組的形式返回數(shù)組的一部分,不包括 end 對應(yīng)的元素击纬,如果省略 end 將復(fù)制start 之后的所有元素鼎姐。
b.arrObj.concat([item1[, item2[, . . . [,itemN]]]]);
將多個數(shù)組(也可以是字符串,或者是數(shù)組和 混合)連接為一個數(shù)組更振,返回連接好的新的數(shù)組

6炕桨、數(shù)組的拷貝

a.arrObj.slice(0);
返回數(shù)組的拷貝數(shù)組,注意是一個新的數(shù)組肯腕,不是指向
b.arrObj.concat();
返回數(shù)組的拷貝數(shù)組献宫,注意是一個新的數(shù)組,不是指向

7实撒、數(shù)組元素的排序

a.arrObj.reverse();
反轉(zhuǎn)元素(最前的排到最后姊途,最后的排到最前)返回新的數(shù)組地址
b.arrObj.sort();
對數(shù)組元素進行排序,返回數(shù)組地址

8知态、數(shù)組元素的字符串化

a.arrObj.join(separator);
返回字符串捷兰,這個字符串將數(shù)組的每一個元素值連接在一起,中間用separator隔開负敏。
toLocaleString 贡茅、toString 、valueOf:可以看作是join的特殊用法其做,不常用

二顶考、數(shù)組對象的3個屬性

1、length 屬性
Length屬性表示數(shù)組的長度妖泄,即其中元素的個數(shù)驹沿。因為數(shù)組的索引總是由0開始,所以一個數(shù)組的上下限分別是:0和length-1蹈胡。和其他大多數(shù)語言不同的是渊季,JavaScript數(shù)組的length屬性是可變的,這一點需要特別注意审残。當(dāng)length屬性被設(shè)置得更大時梭域,整個數(shù)組的狀態(tài)事實上不會發(fā)生變化斑举,僅僅是length屬性變大搅轿;當(dāng)length屬性被設(shè)置得比原來小時,則原先數(shù)組中索引大于或等于length的元素的值全部被丟失富玷。下面是演示改變length屬性的例子:

var arr=[12,23,5,3,25,98,76,54,56,76];
//定義了一個包含10個數(shù)字的數(shù)組
alert(arr.length); //顯示數(shù)組的長度10
arr.length=12; //增大數(shù)組的長度
alert(arr.length); //顯示數(shù)組的長度已經(jīng)變?yōu)?2
alert(arr[8]); //顯示第9個元素的值璧坟,為56
arr.length=5; //將數(shù)組的長度減少到5既穆,索引等于或超過5的元素被丟棄
alert(arr[8]); //顯示第9個元素已經(jīng)變?yōu)?undefined"
arr.length=10; //將數(shù)組長度恢復(fù)為10
alert(arr[8]); //雖然長度被恢復(fù)為10,但第9個元素卻無法收回雀鹃,顯示"undefined"

由上面的代碼我們可以清楚的看到length屬性的性質(zhì)幻工。但length對象不僅可以顯式的設(shè)置存淫,它也有可能被隱式修改柱恤。JavaScript中可以使用一個未聲明過的變量奋蔚,同樣区丑,也可以使用一個未定義的數(shù)組元素(指索引超過或等于length的元素)版述,這時广料,length屬性的值將被設(shè)置為所使用元素索引的值加1钦扭。例如下面的代碼:

var arr=[12,23,5,3,25,98,76,54,56,76];
alert(arr.length);
arr[15]=34;
alert(arr.length);

代碼中同樣是先定義了一個包含10個數(shù)字的數(shù)組戒劫,通過alert語句可以看出其長度為10嗅骄。隨后使用了索引為15的元素胳挎,將其賦值為15,即 arr[15]=34溺森,這時再用alert語句輸出數(shù)組的長度慕爬,得到的是16。無論如何屏积,對于習(xí)慣于強類型編程的開發(fā)人員來說医窿,這是一個很令人驚訝的特性。事實上炊林,使用new Array()形式創(chuàng)建的數(shù)組留搔,其初始長度就是為0,正是對其中未定義元素的操作铛铁,才使數(shù)組的長度發(fā)生變化隔显。
由上面的介紹可以看到,length屬性是如此的神奇饵逐,利用它可以方便的增加或者減少數(shù)組的容量括眠。因此對length屬性的深入了解,有助于在開發(fā)過程中靈活運用倍权。
2掷豺、prototype 屬性
返回對象類型原型的引用。prototype 屬性是 object 共有的薄声。
objectName.prototype
objectName 參數(shù)是object對象的名稱当船。
說明:用 prototype 屬性提供對象的類的一組基本功能。 對象的新實例“繼承”賦予該對象原型的操作默辨。
對于數(shù)組對象德频,以以下例子說明prototype 屬性的用途。
給數(shù)組對象添加返回數(shù)組中最大元素值的方法缩幸。要完成這一點壹置,聲明一個函數(shù)竞思,將它加入 Array.prototype, 并使用它钞护。

function array_max() {
    var i,
    max = this[0];
    for (i = 1; i < this.length; i++){
        if (max < this[i])
        max = this[i];
    }
    return max;
}
Array.prototype.max = array_max;
var x = new Array(1, 2, 3, 4, 5, 6);
var y = x.max();

該代碼執(zhí)行后盖喷,y 保存數(shù)組 x 中的最大值,或說 6难咕。
3课梳、constructor 屬性
表示創(chuàng)建對象的函數(shù)。
object.constructor //object是對象或函數(shù)的名稱余佃。
說明:constructor 屬性是所有具有 prototype 的對象的成員惦界。它們包括除 Global 和 Math 對象以外的所有 JScript 固有對象。constructor 屬性保存了對構(gòu)造特定對象實例的函數(shù)的引用咙冗。
例如:

x = new String("Hi");
if (x.constructor == String) // 進行處理(條件為真)沾歪。
或
function MyFunc {
   // 函數(shù)體。
}
y = new MyFunc;
if (y.constructor == MyFunc) // 進行處理(條件為真)雾消。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末灾搏,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子立润,更是在濱河造成了極大的恐慌狂窑,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,807評論 6 518
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件桑腮,死亡現(xiàn)場離奇詭異泉哈,居然都是意外死亡,警方通過查閱死者的電腦和手機破讨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,284評論 3 399
  • 文/潘曉璐 我一進店門丛晦,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人提陶,你說我怎么就攤上這事烫沙。” “怎么了隙笆?”我有些...
    開封第一講書人閱讀 169,589評論 0 363
  • 文/不壞的土叔 我叫張陵锌蓄,是天一觀的道長。 經(jīng)常有香客問我撑柔,道長瘸爽,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,188評論 1 300
  • 正文 為了忘掉前任铅忿,我火速辦了婚禮剪决,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己昼捍,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 69,185評論 6 398
  • 文/花漫 我一把揭開白布肢扯。 她就那樣靜靜地躺著妒茬,像睡著了一般。 火紅的嫁衣襯著肌膚如雪蔚晨。 梳的紋絲不亂的頭發(fā)上乍钻,一...
    開封第一講書人閱讀 52,785評論 1 314
  • 那天,我揣著相機與錄音铭腕,去河邊找鬼银择。 笑死,一個胖子當(dāng)著我的面吹牛累舷,可吹牛的內(nèi)容都是我干的浩考。 我是一名探鬼主播,決...
    沈念sama閱讀 41,220評論 3 423
  • 文/蒼蘭香墨 我猛地睜開眼被盈,長吁一口氣:“原來是場噩夢啊……” “哼析孽!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起只怎,我...
    開封第一講書人閱讀 40,167評論 0 277
  • 序言:老撾萬榮一對情侶失蹤袜瞬,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后身堡,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體邓尤,經(jīng)...
    沈念sama閱讀 46,698評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,767評論 3 343
  • 正文 我和宋清朗相戀三年贴谎,在試婚紗的時候發(fā)現(xiàn)自己被綠了汞扎。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,912評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡擅这,死狀恐怖佩捞,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情蕾哟,我是刑警寧澤一忱,帶...
    沈念sama閱讀 36,572評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站谭确,受9級特大地震影響帘营,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜逐哈,卻給世界環(huán)境...
    茶點故事閱讀 42,254評論 3 336
  • 文/蒙蒙 一芬迄、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧昂秃,春花似錦禀梳、人聲如沸杜窄。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,746評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽塞耕。三九已至,卻和暖如春嘴瓤,著一層夾襖步出監(jiān)牢的瞬間扫外,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,859評論 1 274
  • 我被黑心中介騙來泰國打工廓脆, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留筛谚,地道東北人。 一個月前我還...
    沈念sama閱讀 49,359評論 3 379
  • 正文 我出身青樓停忿,卻偏偏與公主長得像驾讲,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子席赂,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,922評論 2 361

推薦閱讀更多精彩內(nèi)容