成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

JavaScript引用類型——“Array類型”的注意要點

AlphaWatch / 1855人閱讀

摘要:創(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";

《js 高級程序設計》提到:

數(shù)組最多可以包含4 294 967 295 個項。

檢測數(shù)組

使用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) + "
"); }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 */
歸并方法(ECMAScript 5 新增)

兩個方法: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

相關文章

  • Javascript變量注意要點

    摘要:如很明顯可以看到,實際上是函數(shù)的局部變量。簡單的說就是,復制給參數(shù),在函數(shù)內(nèi)部是局部變量,無論怎么變化,都不影響的變化。 ECMAScript 變量可能包含兩種不同數(shù)據(jù)類型的值:基本類型值和引用類型值。 基本類型和引用類型的值 基本類型值(String,Number,Boolean,Null,Undefined)指的是簡單的數(shù)據(jù)段;引用類型值(保存在內(nèi)存中的對象)指的是那些可能由多個值...

    booster 評論0 收藏0
  • Javascript引用類型——“Object類型注意要點

    摘要:類型關于引用類型的概念引用類型引用類型的值對象是引用類型的一個實例對象是某個特定引用類型的實例新對象用操作符后跟一個構造函數(shù)來創(chuàng)建的如代碼這行代碼創(chuàng)建了引用類型的一個新實例,然后把該實例保存在了變量中。使用的構造函數(shù)是。 Object 類型 關于引用類型的概念: 引用類型:引用類型的值(對象)是引用類型的一個實例; 對象:是某個特定引用類型的實例; 新對象:用new 操作符后跟一個構...

    Codeing_ls 評論0 收藏0
  • JavaScript引用類型——“單體內(nèi)置對象”注意要點

    摘要:單體內(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 對象 所有在全局作用域中定義的屬性...

    xushaojieaaa 評論0 收藏0
  • JavaScript 代碼優(yōu)化和部署——“可維護性”注意要點

    摘要:代碼約定可讀性以下地方需要進行注釋函數(shù)和方法注釋參數(shù)代表什么,是否有返回值大段代碼描述任務的注釋復雜的算法變量和函數(shù)命名變量用名詞函數(shù)名用動詞開頭等返回布爾值類型的函數(shù)用等合乎邏輯不用擔心太長變量類型透明化方法一初始化,如下推薦方法二匈牙利 代碼約定 可讀性 以下地方需要進行注釋: 函數(shù)和方法:注釋參數(shù)代表什么,是否有返回值; 大段代碼:描述任務的注釋; 復雜的算法; Hack 變...

    scwang90 評論0 收藏0
  • JavaScript引用類型——“Date類型注意要點

    摘要:類型中的類型使用自,國際協(xié)調(diào)時間年月日午夜零時開始經(jīng)過的毫秒數(shù)來保存日期。類型保存的日期能夠精確到年月日之前或之后的年。和的輸出因瀏覽器不同而有所差異如年月日上午方法可用比較操作符來比較日期值。 Date 類型 ECMAScript 中的Date 類型使用自UTC(Coordinated Universal Time,國際協(xié)調(diào)時間)1970 年1 月1 日午夜(零時)開始經(jīng)過的毫秒數(shù)來...

    brianway 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<