[js物件]JS入門之Array物件

哈哈哈哈哈我撒發表於2009-07-08

每天一物件,今天我們也來new一個。沒有系統的學過JS,沒有特別的寫過一個比較出色的類庫,沒有運用過一個很強的類庫,prototype.js在進行著,慢慢的前進相信不久的將來就可以應用prototype.js來開發自己的應用程式了。不過在學指令碼prototype.js的過程中發現有些方法我們很少用到,但是有些方法好像很經典,指令碼庫在不斷的加大,眼前一片...繼續我們JS入門,今天學習一下Array陣列。

  首先我們來看看它的定義:

  var arrayObj = new Array()
  var arrayObj 
= new Array([size])
  var arrayObj 
= new Array([element0[, element1[, [, elementN]]]])


  其中:arrayObj是賦值為 Array 物件的變數名。 
        size由於陣列的下標是從零開始,建立的元素的下標將從零到 size -1。 
        element0,...,elementN這將建立具有 n + 1 個元素的長度為 n + 1 的陣列。使用該語法時必須有一個以上元素。

  如果只向 Array 的建構函式傳遞了一個引數,而該引數是數字,則它必須是無符號 32 位整數(大約 40 億)。該值成為陣列的大小。如果該值為數值,但小於 0 或不為整數,發生執行時錯誤。

  如果傳遞給 Array 建構函式的是單個值並且不是數值,設定 length 屬性為 1,而且唯一的元素值成為單個的傳入的引數。

  由於JS陣列為解析陣列,也就是儘管可以分配多個元素給一個陣列,但實際上只有包含資料的元素才存在。這減少了陣列使用的記憶體數量。

  Array物件具有三個內建屬性:constructor,length,prototype我會在特地寫一篇關於constructor, prototype,arguments等物件屬性的文章,在這裡就不在多說了。下面我們主要看看Array內建的一些方法,這個對我們很重要,因為會經常用得這個東東。

  concat方法:連線兩個或多個陣列並返回一個新的陣列。值得我們注意的是(引用型別)對於從正被連線到新陣列的陣列中複製的物件引數,複製後仍然指向相同的物件,不論新陣列和源陣列中哪一個有改變,都將引起另一個的改變; (值型別)對於連線到新陣列的數值或字串,只複製其值,一個陣列中值有改變並不影響另一個陣列中的值。例子:

 1 function ConcatArrayDemo(){
 2    var a, b, c, d;
 3    a = new Array(1,2,3);
 4    b = "JScript";
 5    c = new Array(42"VBScript);
 6    d = a.concat(b, c);
 7    // 返回陣列 [1, 2, 3, "JScript", 42, "VBScript"]
 8    return(d);
 9 }
10 

  join方法:將陣列中的項,按特定的分隔符轉化為字串並返回,預設分隔符為逗號,例子:

1 function JoinDemo(){
2    var a, b;
3    a = new Array(0,1,2,3,4);
4    b = a.join("-");
5    //返回:"0-1-2-3-4"
6    return(b);
7 }

  pop方法:移除陣列中的最後一個元素,並返回該元素。如果該陣列為空則返回undefined。

  push方法:將以新元素出現的順序新增這些元素如果引數之一為陣列,那麼該陣列將作為單個元素新增到陣列中。如果要合併兩個或多個陣列中的元素,請使用 concat 方法。

  reverse 方法將一個 Array 物件中的元素位置進行反轉。在執行過程中,這個方法並不會建立一個新的 Array 物件。如果陣列是不連續的,reverse 方法將在陣列中建立元素以便填充陣列中的間隔。這樣所建立的全部元素的值都是 undefined。

1 function ReverseDemo(){
2    var a, l;                  // 宣告變數。
3    a = new Array(0,1,2,3,4);  // 建立陣列並賦值。
4    l = a.reverse();           // 反轉陣列的內容。
5    //返回:l=[4,3,2,1,0]
6    return(l);                 // 返回結果陣列。
7 }

  shift 方法可移除陣列中的第一個元素並返回該元素。 
 
  slice 方法返回一個 Array 物件,其中包含了 arrayObj 的指定部分。slice 方法一直複製到 end 所指定的元素,但是不包括該元素。如果 start 為負,將它作為 length + start處理,此處 length 為陣列的長度。如果 end 為負,就將它作為 length + end 處理,此處 length 為陣列的長度。如果省略 end ,那麼 slice 方法將一直複製到 arrayObj 的結尾。如果 end 出現在 start 之前,不復制任何元素到新陣列中。例子:

//除了最後一個元素之外,myArray 中所有的元素都被複制到 newArray 中: 

newArray 
= myArray.slice(0-1)
 

  sort 方法將 Array 物件進行適當的排序;在執行過程中並不會建立新的 Array 物件。如果為 sortfunction 引數提供了一個函式,那麼該函式必須返回下列值之一:

  • 負值,如果所傳遞的第一個引數比第二個引數小。
  • 零,如果兩個引數相等。
  • 正值,如果第一個引數比第二個引數大。
1 function SortDemo(){
2    var a, l;                       // 宣告變數。
3    a = new Array("X" ,"y" ,"d""Z""v","m","r");
4    l = a.sort();                   // 排序陣列。
5    return(l);                      // 返回排序的陣列。
6 }

  splice 方法可以移除從 start 位置開始的指定個數的元素並插入新元素,從而修改 arrayObj。返回值是一個由所移除的元素組成的新 Array 物件。 格式如下:

arrayObj.splice(start, deleteCount, [item1[, item2[, . . . [,itemN]]]])

  toLocaleString 方法 將在Date物件中講解,一般這個方法只是返回給使用者,不作為程式碼中計算。

  unshift 方法將這些元素插入到一個陣列的開始部分,所以這些元素將以引數序列中的次序出現在陣列中。格式如下:

arrayObj.unshift([item1[, item2 [, . . . [, itemN]]]])

 

  valueOf方法&toString() 陣列的元素被轉換為字串,這些字串由逗號分隔,連線在一起。其操作與 Array.toString 和 Array.join 方法相同。 

  到這裡Array物件的所有東東也就差不多了,我把他們整理出來一個是為了能夠鞏固我的指令碼知識,再次宣告很多的例子都是前人留下來的,如果對你有不舒服的感覺請見諒!

 

來源:http://www.cnblogs.com/xdotnet/archive/2007/04/10/javascript_object_array.html

相關文章