javascript 數組Array對象

來源:互聯網
上載者:User

new Array()
new Array(len)
new Array([item0,[item1,[item2,...]]]

使用數組對象的方法:

var objArray=new Array();

objArray.concact([item1[,item2[,....]]]-------------------將參數列表串連到objArray的後面形成一個新的數組並返回,原有數組不受影響。如:var arr=["a","b","c"];
arr.concact("d","e");
將返回包括從"a"到"e"字母元素的數組。而arr本身不受影響。

objArray.join(separator)-----------------以separator指定的字元作為分割符,將數群組轉換為字串,當seperator 為逗號時,其作用和toString()相同。

objArray.pop()---------通俗的講,就是彈出數組的最後一個元素。結合下面的push方法,使得將數組作為棧來使用成為可能。pop方法返回數組最後一個元素的值,並將length屬性減1,即返回後立即丟失最後一個元素。

objArray.push([value1[,value2[,....]]])-------------將參數添加到數組的結尾。如:[1,2,3, 4].push("a","b")將得到[1,2,3,4,"a","b"]

objArray.reverse()將數組中的元素反轉排列。如:[1,2,3].reverse()將得到[3,2,1],這個操作是在原有數組上經行操作,同時也返回數組本身
objArray.shift()-----------移去數組的第一個元素,並返回這個元素的值。這個方法的性質和pop方法很類似,pop方法是移去最後一個元素。

objArray.slice(start,end)-----------返回數組對象的一個子集,索引從start開始(包括 start),到end結束(不包括end),原有數組不受影響。如:[1,2,3,4,5,6].slice(1,4)將得到[2,3,4]。當start或者end為負數時,則使用他們加上length後地值。如:[1,2,3,4,5,6].slice(-4,-1)將得到[3,4,5]。如果end小於等於start,將返回空數組。

objArray.sort(comparefn)-------根據comparefn定義的大小比較函數,對一個數組進行排序。函數comparefn必須接受兩個參數element1,element2,如果需要需要element1排在element2之前,應該返回一個負數;如果需要element1排在element2之後,應該返回一個正數,如果兩個數平等對待(即保持原有順序)則返回0。當省略comparefn時,則元素按照字典順序排列。如:對定義的比較函數cmp: function cmp(e1,e2){return e1-e2;}則[3,4,2,7].sort(cmp)將得到[2,3,4,7].
objArray.splice(start,deleteCount[,item1,item2[,...]]])這是一個複雜的函數,用於完成數組元素的刪除 取代和插入操作。其中,start參數表示要進行操作的索引位置,deleteCount指從start開始要刪除的元素的元素個數(包括了start位置),如果deleteCount省略,則表示從start開始要刪除數組的剩餘部分。[,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[,...]]])-------------------將參數列表插入到數組的開頭。其性質和push方法類型,但push方法是將元素添加到數組的結尾。如:[1,2,3,4].unshift("a","b")將得到["a","b",1,2,3,4]。

從大到小冒泡排序法:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<head>
<title> New Document </title>
<meta name="Generator" content="EditPlus">
<meta name="Author" content="">
<meta name="Keywords" content="">
<meta name="Description" content="">
</head>

<body>
<script language="JavaScript" type="text/javascript">
<!--
function bubbleSort(arr){
    //外層迴圈,共要進行arr.length次求最大值操作
    for(var i=0;i<arr.length;i++){
        //內層迴圈,找到第i大的元素,並將其和第i個元素交換
        for(var j=i;j<arr.length;j++){
            if(arr[i]<arr[j]){
                //交換兩個元素的位置
                var temp=arr[i];
                arr[i]=arr[j];
                arr[j]=temp;
            }
        }
    }
}

var arr=[32,55,78,43,78,10,45,20,9,89];
bubbleSort(arr);

//輸出:89,78,78,55,45,43,32,20,10,9
for(var i=0;i<arr.length;i++){
    document.write(arr[i]+",");
}
//-->
</script>

</body>
</html>

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.