IT培訓(xùn)網(wǎng)
IT在線學(xué)習(xí)
valueOf(),toString()
valueOf方法是一個所有對象都擁有的方法,表示對該對象求值。不同對象的valueOf方法不盡一致,數(shù)組的valueOf方法返回數(shù)組本身。
toString方法也是對象的通用方法,數(shù)組的toString方法返回數(shù)組的字符串形式。
- var arr = [1, 2, 3];
- arr.toString() // "1,2,3"
push(),pop()
push方法用于在數(shù)組的末端添加一個或多個元素,并返回添加新元素后的數(shù)組長度。注意,該方法會改變原數(shù)組。
- var arr = [];
- arr.push(1);
- arr.push('a');
- arr.push(true, {})
- console.log(arr); // [1, 'a', true, {}]
上面代碼使用push方法,往數(shù)組中添加了四個成員。
pop方法用于刪除數(shù)組的最后一個元素,并返回該元素。注意,該方法會改變原數(shù)組。
- var arr = [1, 2, 3];
-
- console.log(arr.pop()); // 3
- console.log(arr); // ['a', 'b']
對空數(shù)組使用pop方法,不會報錯,而是返回undefined。
shift(),unshift()
shift()方法用于刪除數(shù)組的第一個元素,并返回該元素。注意,該方法會改變原數(shù)組。
- var arr = ['a', 'b', 'c'];
- arr.shift(); // 'a'
- arr; // ['b', 'c']
上面代碼中,使用shift()方法以后,原數(shù)組就變了。
unshift()方法用于在數(shù)組的第一個位置添加元素,并返回添加新元素后的數(shù)組長度。注意,該方法會改變原數(shù)組。
- var arr = ['a', 'b', 'c'];
- arr.unshift('x'); // 4
- arr; // ['x', 'a', 'b', 'c']
unshift()方法可以接受多個參數(shù),這些參數(shù)都會添加到目標數(shù)組頭部。
- var arr = [ 'c', 'd' ];
- arr.unshift('a', 'b') // 4
- arr // [ 'a', 'b', 'c', 'd' ]
join()
join()方法以指定參數(shù)作為分隔符,將所有數(shù)組成員連接為一個字符串返回。如果不提供參數(shù),默認用逗號分隔。
- var a = [1, 2, 3, 4];
- a.join(' ') // '1 2 3 4'
- a.join(' | ') // "1 | 2 | 3 | 4"
- a.join() // "1,2,3,4"
concat()
concat方法用于多個數(shù)組的合并。它將新數(shù)組的成員,添加到原數(shù)組成員的后部,然后返回一個新數(shù)組,原數(shù)組不變。
- ['hello'].concat(['world']); // ["hello", "world"]
- ['hello'].concat(['world'], ['!']);// ["hello", "world", "!"]
除了數(shù)組作為參數(shù),concat也接受其他類型的值作為參數(shù),添加到目標數(shù)組尾部。
- [1, 2, 3].concat(4, 5, 6); // [1, 2, 3, 4, 5, 6]
reverse()
reverse方法用于顛倒排列數(shù)組元素,返回改變后的數(shù)組。注意,該方法將改變原數(shù)組。
- var a = ['a', 'b', 'c'];
- a.reverse(); // ["c", "b", "a"]
- a; // ["c", "b", "a"]
slice()
slice()方法用于提取目標數(shù)組的一部分,返回一個新數(shù)組,原數(shù)組不變。 arr.slice(start, end);
它的第一個參數(shù)為起始位置(從0開始,會包括在返回的新數(shù)組之中),第二個參數(shù)為終止位置(但該位置的元素本身不包括在內(nèi))。如果省略第二個參數(shù),則一直返回到原數(shù)組的最后一個成員。
- var a = ['a', 'b', 'c'];
- a.slice(0); // ["a", "b", "c"]
- a.slice(1); // ["b", "c"]
- a.slice(1, 2); // ["b"]
- a.slice(2, 6); // ["c"]
- a.slice(); // ["a", "b", "c"]
如果slice()方法的參數(shù)是負數(shù),則表示倒數(shù)計算的位置。
splice()
splice()方法用于刪除原數(shù)組的一部分成員,并可以在刪除的位置添加新的數(shù)組成員,返回值是被刪除的元素。注意,該方法會改變原數(shù)組。arr.splice(start, count, addElement1, addElement2, ...);
splice的第一個參數(shù)是刪除的起始位置(從0開始),第二個參數(shù)是被刪除的元素個數(shù)。如果后面還有更多的參數(shù),則表示這些就是要被插入數(shù)組的新元素。
- var a = ['a', 'b', 'c', 'd', 'e', 'f'];
- a.splice(4, 2); // ["e", "f"]
- a; // ["a", "b", "c", "d"]
上面代碼從原數(shù)組4號位置,刪除了兩個數(shù)組成員。
- var a = ['a', 'b', 'c', 'd', 'e', 'f'];
- a.splice(4, 2, 1, 2); // ["e", "f"]
- a; // ["a", "b", "c", "d", 1, 2]
上面代碼除了刪除成員,還插入了兩個新成員。
起始位置如果是負數(shù),就表示從倒數(shù)位置開始刪除。
- var a = ['a', 'b', 'c', 'd', 'e', 'f'];
- a.splice(-4, 2); // ["c", "d"]
上面代碼表示,從倒數(shù)第四個位置c開始刪除兩個成員。
如果只是單純地插入元素,splice方法的第二個參數(shù)可以設(shè)為0。
- var a = [1, 1, 1];
- a.splice(1, 0, 2); // []
- a; // [1, 2, 1, 1]
如果只提供第一個參數(shù),等同于將原數(shù)組在指定位置拆分成兩個數(shù)組。
- var a = [1, 2, 3, 4];
- a.splice(2); // [3, 4]
- a; // [1, 2]
sort()
sort方法對數(shù)組成員進行排序,默認是按照字典順序排序。排序后,原數(shù)組將被改變。
- ['d', 'c', 'b', 'a'].sort()
- // ['a', 'b', 'c', 'd']
- [4, 3, 2, 1].sort()
- // [1, 2, 3, 4]
- [11, 101].sort()
- // [101, 11]
- [10111, 1101, 111].sort()
- // [10111, 1101, 111]
上面代碼的最后兩個例子,需要特殊注意。sort()方法不是按照大小排序,而是按照字典順序。也就是說,數(shù)值會被先轉(zhuǎn)成字符串,再按照字典順序進行比較,所以101排在11的前面。
如果想讓sort方法按照自定義方式排序,可以傳入一個函數(shù)作為參數(shù)。
- [10111, 1101, 111].sort(function (a, b) {
- return a - b;
- })
- // [111, 1101, 10111]
上面代碼中,sort的參數(shù)函數(shù)本身接受兩個參數(shù),表示進行比較的兩個數(shù)組成員。如果該函數(shù)的返回值大于0,表示第一個成員排在第二個成員后面;其他情況下,都是第一個元素排在第二個元素前面。
- [
- { name: "張三", age: 30 },
- { name: "李四", age: 24 },
- { name: "王五", age: 28 }
- ].sort(function (o1, o2) {
- return o1.age - o2.age;
- })
- // [
- // { name: "李四", age: 24 },
- // { name: "王五", age: 28 },
- // { name: "張三", age: 30 }
- // ]
注意,自定義的排序函數(shù)應(yīng)該返回數(shù)值,否則不同的瀏覽器可能有不同的實現(xiàn),不能保證結(jié)果都一致。
以上是對數(shù)組創(chuàng)建方式和常用方法的描述,希望可以讓你對數(shù)組有清晰的了解。
>>本文地址:http://www.yceu.cn/zhuanye/2021/67119.html
聲明:本站稿件版權(quán)均屬中公教育優(yōu)就業(yè)所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
1 您的年齡
2 您的學(xué)歷
3 您更想做哪個方向的工作?