javascript 數組簡明總結

來源:互聯網
上載者:User

標籤:

 

定義

var empty=[];

 

何時使用

當屬性名稱是小而連續的整數時,使用資料群組,否則使用對象。

 

識別

typeof運算子對資料沒有意義,因為返回的是‘object‘
//ECMA5 已添加該方法
可以添加靜態方法:

Array.isArray=function(obj){    return Object.prototype.toString.apply(obj)===‘[object Array]‘}

 

 

長度
  length屬性的值是這個數組的最大整數屬性名稱加1:

array=[];
array[7]=0;
console.log(array.length);

設定更大length不會給數組分配更多的空間(undefined),而把length設小將導致所有下標等於新的length的屬性被刪除。

 

添加

添加一個元素:
empty[empty.length]="";
empty.push("");

 

刪除

delete numbers[2]; //留下一個空洞
numbers.splice(2,1); //向前移動

 

尋找

//IE9+ 支援
array.indexOf()
array.lastIndexOf()

 

輸出

alert(array.toString());alert(array.valueOf());alert(array);alert(array.join(‘,‘));

 

 

方法

  • 字串方法:

array.concat() //連接字串,相當於‘+’
array.join() //產生字串

  • 棧方法:

array.push()
array.pop()

  • 隊列方法

array.shift() 
array.unshift()

  • 重排序方法

array.reverse() //反排序
array.sort() //字串排序

  • 操作方法

array.slice()
array.splice() //相當強大,可實現任意的增刪改。

 

排序

資料原型中有sort的方法(Array.prototype.sort ),但只對字元排序

function sortNumber(a, b){return a - b}var arr = new Array(6)arr[0] = "10"arr[1] = "5"arr[2] = "40"arr[3] = "25"arr[4] = "1000"arr[5] = "1"document.write(arr + "<br />")//字元排序document.write(arr.sort() + "<br />") //1,10,1000,25,40,5//資料排序document.write(arr.sort(sortNumber)) //1,5,10,25,40,1000

  

迭代

在此只介紹簡單用法.//以下只支援ECMA5

every() //每一個都滿足條件返回truefilter() //返回滿足條件的子數組forEach() //對每一個元素進行操作,不返回map() //對每一個元素進行操作,返回結果數組some()//有一個滿足條件返回true

 

歸併

當前後項有關係時實現的操作,方便實現雙向鏈表的功能. //以下只支援ECMA5

reduce()reduceRight()

 

編碼規範

以下來自GitHub,有很多關於javascript優秀的編程風格,推薦大家看看:https://github.com/airbnb/javascript

  • Use the literal syntax for array creation.

    // badvar items =newArray();// goodvar items = [];
  • Use Array#push instead of direct assignment to add items to an array.

    var someStack = [];// badsomeStack[someStack.length] =‘abracadabra‘;// goodsomeStack.push(‘abracadabra‘);
  • When you need to copy an array use Array#slice. jsPerf

    var len = items.length;var itemsCopy = [];var i;// badfor (i =0; i < len; i++) {  itemsCopy[i] = items[i];}// gooditemsCopy = items.slice();
  • To convert an array-like object to an array, use Array#slice.

    functiontrigger() {  var args =Array.prototype.slice.call(arguments);  ...}

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.