摘要:創(chuàng)建數(shù)組讀取和設置數(shù)組的值創(chuàng)建數(shù)組創(chuàng)建數(shù)組的基本方式有兩種使用構造函數(shù)使用數(shù)組字面量表示法對于第一種方法,如果知道數(shù)組要保存多少個項目,也可以給構造函數(shù)傳遞參數(shù),比如要創(chuàng)建值為的數(shù)組操作符可以省略。也可以向構造函數(shù)傳遞包含的項。
Array 類型
除了Object 之外,Array 類型也是相當常用的類型了。ECMAScript 數(shù)組的每一項可以保存任何類型的數(shù)據(jù)。且數(shù)組大小也能夠動態(tài)調(diào)整的。
創(chuàng)建數(shù)組、讀取和設置數(shù)組的值 創(chuàng)建數(shù)組創(chuàng)建數(shù)組的基本方式有兩種:
使用Array 構造函數(shù):var colors = new Array();
使用數(shù)組字面量表示法;
對于第一種方法,如果知道數(shù)組要保存多少個項目,也可以給構造函數(shù)傳遞參數(shù),比如要創(chuàng)建length 值為10 的數(shù)組:
var colors = Array(10); //new 操作符可以省略。
也可以向Array 構造函數(shù)傳遞包含的項。如:
var colors = Array("yellow","red","green");
對于第二種方法,數(shù)組字面量由方括號表示,用逗號隔開。如:
var colors = [ "red", "green", "blue" ] console.log(colors); //["red", "green", "blue"] var boys = []; document.write(boys.length); //0讀取和設置數(shù)組的值
使用方括號和基于0 的數(shù)字索引。如:
var colors = [ "red", "blue", "yellow" ] document.write(colors[1]); //"blue" 訪問第二項 document.write(colors.length); //3 colors[3] = "cc"; document.write(colors.length); //4 創(chuàng)建一個新的項 document.write(colors[3]); //"cc"
length屬性,數(shù)組的項數(shù)就保存在length 屬性中,這個屬性返回0 或更大的值。且該屬性可寫的,可以從數(shù)組的末尾移除或增加項。如:
var colors = [ "red", "blue" ] colors[colors.length] = "yellow"; console.log(colors); // ["red", "blue", "yellow"] 在末尾增加了一項"yellow" colors.length = 2; console.log(colors); // ["red", "blue"] 在末尾減少了一項 colors.length = 3; console.log(colors); //["red", "blue", undefined × 1] 在末尾增加了一項undefined
利用length屬性,可以方便地在數(shù)組末尾添加新項,如:
var colors = ["red"]; colors[colors.length] = "yellow";
檢測數(shù)組《js 高級程序設計》提到:
數(shù)組最多可以包含4 294 967 295 個項。
使用instanceof操作符:if (value instanceof Array) {};
使用ECMAScript 5 新增的Array.isArray()方法:if (Array.isArray(value));
檢測數(shù)組instanceof操作符的問題,在這里不深究。支持Array.isArray()方法的瀏覽器有IE9、FIrefox 4+、Safari 5+、Opera 10.5+和Chrome。
數(shù)組的轉(zhuǎn)換通常,用toString()方法會返回數(shù)組中每個值的字符串形式拼接而成的以逗號分隔開來的字符串;用valueOf()方法則仍然返回數(shù)組。
var colors = ["red","yellow"]; var color1 = colors.toString(); document.write(typeof color1); //string 使用toString() 方法,返回的是用逗號分割的字符串; var color2 = colors.valueOf(); document.write(typeof color2); //object console.log(color2) //使用valueOf() 方法,返回的仍然是數(shù)組;
另外,還可以使用toLocaleString()方法,如:
var person = { toLocaleString:function(){ return "Oliver"; }, toString:function(){ return "Troy"; } }; var age = { toLocaleString:function(){ return "adult"; }, toString:function(){ return "children"; } }; var people = [person,age]; document.write(people.toString()); //Troy,children 返回每個數(shù)組里面的每個對象的toString 返回的值 document.write(people.toLocaleString()); //Oliver,adult 返回每個數(shù)組里面的每個對象的toLocaleString 返回的值 document.write(people.valueOf()); //Troy,children document.write(people.join(" is a ")); //Troy is a children 改變兩個數(shù)組鏈接起來的分隔符
可以使用join()方法來控制數(shù)組的連接符。
棧方法和隊列方法 棧方法(表現(xiàn)的像棧一樣)ECMAScript 數(shù)組可以表現(xiàn)的像棧一樣。棧是一種LIFO(Last-In-First—Out,后進先出),只發(fā)生在一個位置——棧的頂部。
有兩個方法push()和pop()方法。具體的來說,push()方法可以接收任意數(shù)量的參數(shù),把它們逐個添加到數(shù)組的末尾,并返回修改后的數(shù)組的長度;pop()方法則可以從數(shù)組的末尾移除最后一項,減少數(shù)組的length 值,并返回移除的項。如:
添加項:
var array = [1,2,3,4]; console.log(array); //[1, 2, 3, 4] 目前該array 有4項 var count = array.push("str","34"); //末尾增加了一項"str"和一項"34" console.log(count); //6 這時返回的長度增加2 console.log(array); //[1, 2, 3, 4, "str", "34"] console.log(array.length); //6
減少項:
var array = [1,2,3,4]; console.log(array); //[1, 2, 3, 4] 目前該array 有4項 var count = array.pop(); console.log(count); //4 減少了一個"4" console.log(array); //[1, 2, 3]隊列方法
隊列數(shù)據(jù)結(jié)構的訪問規(guī)則是FIFO(First-In-First-Out),結(jié)合使用shift()和push()方法,可以像使用隊列一樣使用數(shù)組。shift()可以移除數(shù)組中的第一個項,并返回該項。如:
var array = []; var count = array.push("1","2"); document.write(count); document.write(array); //[1,2] count = array.push("3"); document.write(count); document.write(array); //[1,2,3] var item = array.shift(); document.write(item); //1 document.write(array); //[2,3]
另外,還有一個叫unshift()方法,同時使用unshift()和pop()方法,可以從相反的方向來模擬隊列,即在前端添加項,末端移除項。如:
var array = []; var count = array.unshift(1,2,3); document.write(count); //3 document.write(array); //[1,2,3] count = array.unshift(0); document.write(count); //4 document.write(array); //[0,1,2,3] item = array.pop(); document.write(item); //3 document.write(array); //[0,1,2]
需要注意的是:
shift()返回的是前端刪除的項的值;
unshift()返回的是前端增加后數(shù)組的長度;
pop()返回的是末端刪除的項的值;
push()返回的是末端增加后數(shù)組的長度。
總的來說就是“刪除返回項的值,增加則返回長度”
重排序方法有兩個重排序方法:reverse()和sort()。
sort()方法按照升序排列數(shù)組項,如:
var array = [4321,3,43,"56",6543,32,65,765]; array.sort(); //3,32,43,4321,56,65,6543,765
亂七八糟,只比較了第一位數(shù)。
比較函數(shù)接收兩個參數(shù),如果第一個參數(shù)應該位于第二個之前,則返回一個復數(shù),如果兩個參數(shù)相等則返回0,如果第一個參數(shù)應該位于第二個參數(shù)后面,則返回一個正數(shù)。通常返回第二個參數(shù)減掉第一個參數(shù)的值就可以了(在數(shù)值類型或其valueOf()方法返回數(shù)值類型的對象類型的情況下)。如:
var array = [3,1,6,"10"]; array.sort(compare); function compare(value1,value2){ return value1 - value2; //如果value1 - value2 是正數(shù),則說明value1 大于value2,value1 應該排在后面。為升序排列; }; document.write(array); //[1,3,6,10]
如果想要降序排列,則修改一下compare函數(shù)成value2 - value1 就可以了。如:
var array = [3,1,6,"10"]; array.sort(compare); function compare(value1,value2){ return value2 - value1; //如果value2 - value1 是正數(shù),則說明value2 大于value1,value1 應該排在后面。為降序排列; }; document.write(array); //[10,6,3,1]
但是如果是任意類型,則不能使用這種方法。而應當對參數(shù)進行比較。如:
var array = ["Oliver","Troy",{name:"troy"},"Alice"]; array = array.sort(compare); document.write(array); //Alice,Oliver,Troy,[object Object] function compare(x,y){ if(x > y){ return 1; }else if(x < y){ return -1; }else{ return 0; } }
或者:
var array = ["Oliver","Troy",{name:"troy"},"Alice"]; array = array.sort(compare); document.write(array); //Alice,Oliver,Troy,[object Object] function compare(x,y){ if(x < y){ return 1; }else if(x > y){ return -1; }else{ return 0; } }
如果只是想翻轉(zhuǎn)原來數(shù)組的順序,使用reverse()方法就行了,如:
var array = [3,1,6,"10"]; array.reverse(); document.write(array); //10,6,1,3操作方法
concat()方法,主要作用就是復制當前的數(shù)組并返回副本。如:(不影響原始數(shù)組)
var array = ["abc",123,{name:"Oliver"}]; var newArray = array.concat("abc",[123,32,{age:18}]); document.write(newArray); // abc,123,[object Object],abc,123,32,[object Object]
slice()方法,主要作用是基于當前數(shù)組中的一個或多個項創(chuàng)建的一個新數(shù)組。如:(不影響原始數(shù)組)
var array = ["a","b","c","d"]; var newArray = array.slice(2); document.write(newArray); //c,d newArray = array.slice(1,2); document.write(newArray); //b
如果只有一個參數(shù),返回從該參數(shù)指定位置到數(shù)組末尾的所有項;如果有兩個參數(shù),返回起始位置和結(jié)束位置之間的項,但不包括結(jié)束位置的項。如果,參數(shù)中有負數(shù),則用數(shù)組長度加上該數(shù)來確定相應的位置。
splice()的主要用法:
刪除,2個參數(shù):要刪除的第一項和要刪除的項數(shù);
插入,3個參數(shù):起始位置、0(要刪除的項數(shù))和要插入的項;
替換,3個參數(shù):起始位置、要刪除的項數(shù)和要插入的任意數(shù)量的項;
該方法始終都會返回一個數(shù)組。舉個例子:
刪除:
var cars = ["寶馬","奔馳","沃爾沃"]; var deleteCar = cars.splice(1, 2); console.log(deleteCar); //["奔馳", "沃爾沃"]
插入:
var cars = ["寶馬","奔馳","沃爾沃"]; var addCar = cars.splice(1, 0, "特斯拉","保時捷"); console.log(cars); //["寶馬", "特斯拉", "保時捷", "奔馳", "沃爾沃"]
替換:
var cars = ["寶馬","奔馳","沃爾沃"]; var replaceCar = cars.splice(1, 1, "保時捷"); console.log(replaceCar); //["奔馳"] 刪除了奔馳 console.log(cars); //["寶馬", "保時捷", "沃爾沃"] 用保時捷替換了奔馳位置方法
indexOf()方法和lastIndexOf()方法。一個是從數(shù)組的開頭(位置0)開始向后查找;另一個則是從數(shù)組的末尾開始向前查找。有兩個參數(shù):要查找的項和表示查找起點的位置索引。在比較第一個參數(shù)與數(shù)組中的每一項時,會使用全等操作符。如:
var numbers = [1,2,3,4,5,3]; document.write(numbers.indexOf(4)); //3 document.write(numbers.indexOf(4,5)); //-1 從第5索引開始查找,找不到就返回-1 document.write(numbers.lastIndexOf(3)); //5 document.write(numbers.lastIndexOf(3,0)); //-1 從第0索引開始反向查找,找不到就返回-1 document.write(numbers.indexOf(3)); //2 這里有兩個3 但是當搜索到第一個時就會停止搜索
Mark!?。。。?!
Mark?。。。。。?/strong>
Mark?。。。。?!
var oliver = {name:"oliver"}; var person = [{name:"oliver"}]; var people = [oliver]; document.write(person.indexOf({name:"oliver"})); //-1 document.write(person.indexOf(oliver)); //-1 document.write(people.indexOf({name:"oliver"})); //-1 document.write(people.indexOf(oliver)); //0 必須變量搜索變量迭代方法和歸并方法 迭代方法
有5 個迭代方法,每個方法接收兩個參數(shù):要在每一項上運行的函數(shù)和作用域?qū)ο螅蛇x);傳入這些方法中的函數(shù)則接收三個參數(shù):數(shù)組項的值(item)、索引位置(index)、數(shù)組對象本身(array)。
every():每一項運行該函數(shù),如果都返回true,則返回true;(返回Noolean)(主要是驗證)
some():每一項運行該函數(shù),如果其中任一項返回true,則返回true;(返回Boolean)(主要是驗證)
filter():每一項運行該函數(shù),對于那些返回true的項,組成一個數(shù)組;(返回Array)(主要是驗證)
map():每一項運行該函數(shù),返回的結(jié)果組成一個數(shù)組;(返回Array)(對數(shù)組操作)
forEach():每一項運行該函數(shù),沒有返回值;(不返回)(對數(shù)組操作)(本質(zhì)上與for 語句類似)
下面是例子:
every():
var numbers = [1,3,2,5,4]; var result = numbers.every(function(item, index, array){ return item > 0; }); document.write(result); //都大于零,返回true
some():
var numbers = [1,5,4,32]; var result = numbers.some(function(item, index, Array){ return item > 31; }); document.write(result); //true 數(shù)組中至少有一項滿足條件,返回true
filter():
var array = [123,"Oliver","Troy",true]; var newArray = array.filter(function(item, index, array){ return typeof item == "string"; }); console.log(newArray); //["Oliver", "Troy"] 把滿足條件的部分返回一個數(shù)組
map():
var array = [123,"Oliver","Troy",true]; var newArray = array.map(function(item, index, array){ return item += " (Oliver)"; }); console.log(newArray); //["123 (Oliver)", "Oliver (Oliver)", "Troy (Oliver)", "true (Oliver)"]
forEach():
var array = [123,"Oliver","Troy",true]; array.forEach(function(item, index, array){ if (typeof item == "number"){ document.write((item + 877) + "歸并方法(ECMAScript 5 新增)
"); }else if (typeof item == "string"){ document.write("This is a string: " + item + "
") }else{ document.write(item + "ly") } }); /* 1000 This is a string: Oliver This is a string: Troy truely */
兩個方法:reduce()和reduceRight(),這兩個方法都會迭代數(shù)組的所有項,然后構建一個最終返回的值。前者是從數(shù)組的第一項開始,后者是從數(shù)組的最后一項開始。他們有兩個參數(shù):一個在每一項上調(diào)用的函數(shù)和最為歸并基礎的初始值。函數(shù)則包括4 個參數(shù):前一個值(prev)、當前值(cur)、項的索引(index)、數(shù)組本身(array)。如:
var numbers = [1,3,2,4,5,7,6]; var result = numbers.reduce(function(prev, cur, index, array){ return prev + cur; }); console.log(result); //28
又如:
var array = [321,false,"Oliver",21]; var newArray = array.reduce(function(prev, cur, index, array){ return prev + cur; }); console.log(newArray); //321Oliver21 newArray = array.reduceRight(function(prev, cur, index, array){ return prev + cur; }); console.log(newArray); //21Oliverfalse321 這里出現(xiàn)了false 是因為+ 操作符的原因 console.log(21+"oliver"+false+321); //false 被轉(zhuǎn)換成字符串 console.log(321+false+"oliver"+21); //false 被轉(zhuǎn)換成數(shù)值 console.log(321+(false+"oliver"+21)); //false 被轉(zhuǎn)換字符串,括號的原因
(今天內(nèi)容還真是有點多,看007去了,回來再復習)
文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/86198.html
摘要:如很明顯可以看到,實際上是函數(shù)的局部變量。簡單的說就是,復制給參數(shù),在函數(shù)內(nèi)部是局部變量,無論怎么變化,都不影響的變化。 ECMAScript 變量可能包含兩種不同數(shù)據(jù)類型的值:基本類型值和引用類型值。 基本類型和引用類型的值 基本類型值(String,Number,Boolean,Null,Undefined)指的是簡單的數(shù)據(jù)段;引用類型值(保存在內(nèi)存中的對象)指的是那些可能由多個值...
摘要:類型關于引用類型的概念引用類型引用類型的值對象是引用類型的一個實例對象是某個特定引用類型的實例新對象用操作符后跟一個構造函數(shù)來創(chuàng)建的如代碼這行代碼創(chuàng)建了引用類型的一個新實例,然后把該實例保存在了變量中。使用的構造函數(shù)是。 Object 類型 關于引用類型的概念: 引用類型:引用類型的值(對象)是引用類型的一個實例; 對象:是某個特定引用類型的實例; 新對象:用new 操作符后跟一個構...
摘要:單體內(nèi)置對象單體內(nèi)置對象就是開發(fā)人員不必顯式地實例化內(nèi)置對象,因為他們已經(jīng)實例化了。前面的章節(jié)討論過了大多數(shù)內(nèi)置對象,還定義了兩個單體內(nèi)置對象和。 單體內(nèi)置對象 單體內(nèi)置對象就是開發(fā)人員不必顯式地實例化內(nèi)置對象,因為他們已經(jīng)實例化了。前面的章節(jié)討論過了大多數(shù)內(nèi)置對象,ECMA-262 還定義了兩個單體內(nèi)置對象:Global 和Math。 Global 對象 所有在全局作用域中定義的屬性...
摘要:代碼約定可讀性以下地方需要進行注釋函數(shù)和方法注釋參數(shù)代表什么,是否有返回值大段代碼描述任務的注釋復雜的算法變量和函數(shù)命名變量用名詞函數(shù)名用動詞開頭等返回布爾值類型的函數(shù)用等合乎邏輯不用擔心太長變量類型透明化方法一初始化,如下推薦方法二匈牙利 代碼約定 可讀性 以下地方需要進行注釋: 函數(shù)和方法:注釋參數(shù)代表什么,是否有返回值; 大段代碼:描述任務的注釋; 復雜的算法; Hack 變...
摘要:類型中的類型使用自,國際協(xié)調(diào)時間年月日午夜零時開始經(jīng)過的毫秒數(shù)來保存日期。類型保存的日期能夠精確到年月日之前或之后的年。和的輸出因瀏覽器不同而有所差異如年月日上午方法可用比較操作符來比較日期值。 Date 類型 ECMAScript 中的Date 類型使用自UTC(Coordinated Universal Time,國際協(xié)調(diào)時間)1970 年1 月1 日午夜(零時)開始經(jīng)過的毫秒數(shù)來...
閱讀 2425·2021-11-16 11:44
閱讀 1893·2021-10-12 10:12
閱讀 2190·2021-09-22 15:22
閱讀 3020·2021-08-11 11:17
閱讀 1518·2019-08-29 16:53
閱讀 2665·2019-08-29 14:09
閱讀 3484·2019-08-29 14:03
閱讀 3313·2019-08-29 11:09