JavaScript基礎知識(數組)

來源:互聯網
上載者:User

標籤:ber   array   檢測   ring   轉換   數組   個數   沒有   height   

 21、數組

  • 定義數組

* 字面量方式

       var 數組名稱 = [ value,value,... ]

* 建構函式方式

      var 數組名稱 = new Array(value,value,...)  var 數組名稱 = new Array(length)

              建立對象方式建立數組分析圖

 

附:var num1 = 100; // number            var num2 = new Number(100); // object

     var str1 = ‘string‘; // string             var str2 = new String(‘string‘); // object

     var boo1 = true; // Boolean            var boo2 = new Boolean(true); // object

     var arr1 = [1,2,3,4]; // object          var arr2 = new Array(1,2,3,4); // object

     數組分類

2       索引數組 - 預設建立的數組

 (1)建立了空數組  (2)基於空數組建立索引數組    

格式:var 數組名稱 = new Array( );  數組名稱[索引值] =值; 

索引值是數字(從0開始)】

註:當在某個具體位置上沒有儲存任何值時 - undefined

2     關聯陣列 - 類似於JavaScript的對象

格式:var 數組名稱 = new Array( );  數組名稱[索引值] =值;索引值是字串】

註:ECMAScript官方規範中並沒有提供關聯陣列的概念

    稀疏數組

概念:數組的長度大於數組中元素的個數   數組中元素沒有值的情況下,預設undefined

u    數組的屬性-長度

非稀疏數組:  length 屬性的值 = 當前數組包含元素的個數。

稀疏數組:    length 屬性的值 > 當前數組包含元素的個數。

eg: var arr2 = [ ];    arr2[14] = ‘a’ ;  console.log( arr2.length );// 輸出 15

   操作(擷取/修改/刪除)

2  擷取數組中的元素:數組名稱[索引值]

2 修改數組中的元素:數組名稱[索引值] = 新的值

2 刪除數組中的元素:delete 數組名稱[索引值]

註:只刪除對應位置上的值,但位置保留 - undefined

u  遍曆數組

     * for語句: 遍曆數組可以控制的開始和結束

     * for.in語句:只能遍曆數組從開始到結束

u  變數與數組

                                                                變數的賦值操作解析圖

 

              數組的賦值操作解析圖

 

u  二維數組

概念: 數組的嵌套結構   遍曆:for嵌套語句

l  常見的操作方法

  • 檢測資料類型
  • 轉換方法  toString( )
  • 進出棧—添加/刪除   【對原數組有影響;刪除則返回元素 添加則返回長度】

push( ) - 向數組的最後添加元素                pop() - 刪除數組中最後一個元素

unshfit( ) - 向數組的開始添加元素              shfit( ) - 刪除數組中第一個元素                

  • 排序方法

reverse( ) - 顛倒數組中元素的順序

sort( ) - 對數組的元素進行排序

【注: 預設排序不是由小到大的排序。若是兩位元,則按第一位元來排列】

方法:通過 數組名稱.sort( ) 裡面建構函式,來改變預設的排序,使得按順序序排列。

eg:  arr.sort(function(a,b){

       return a < b ;                     ------  < 由大到小;  > 由小到大

        });                   

  • 截取方法:

2 slice(start,end)                                  【註:對原數組沒有任何影響】                             

start---表示從數組的哪個索引值開始截取;       end---預設情況下,表示數組最後結束

設定值: 表示截取到當前索引值的前一個         傳回值: 截取的結果

var arr1 = arr.slice(1,3);    console.log(arr,arr1);

2 splice(index, howmany, element1,element2,...elementN)      【註:預設是一個數組】

index---表示當前數組的索引值(刪除或添加的位置)

howmany ---表示刪除元素的個數(若為0,則表示不刪除)     element1---表示添加的元素

* 注意 - 被添加到數組的 index 位置上;       傳回值 - 表示當前刪除的元素

  • 搜尋內容—>位置

indexOf(element)

element - 表示在數組中搜尋的元素內容

用法:從數組中索引值為0開始搜尋,依次向後;   傳回值:第一個匹配的元素的索引值

註:如果搜尋的元素在數組中不存在,則返回 -1

2   lastIndexOf(element)

element - 表示在數組中搜尋的元素內容

用法:                                     傳回值:最後一個匹配的元素的索引值

 

JavaScript基礎知識(數組)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.