最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

JavaScript數(shù)組常用操作技巧

來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 20:28:29
文檔

JavaScript數(shù)組常用操作技巧

JavaScript數(shù)組常用操作技巧:前言相信大家都用慣了jquery或者underscore等這些類庫中常用的數(shù)組相關(guān)的操作,如$.isArray,_.some,_.find等等方法。這里無非是對(duì)原生js的數(shù)組操作多了一些包裝。這里主要匯總一下JavaScript數(shù)組操作的常用API。相信對(duì)大家解決程序問題很有幫助。一、性
推薦度:
導(dǎo)讀JavaScript數(shù)組常用操作技巧:前言相信大家都用慣了jquery或者underscore等這些類庫中常用的數(shù)組相關(guān)的操作,如$.isArray,_.some,_.find等等方法。這里無非是對(duì)原生js的數(shù)組操作多了一些包裝。這里主要匯總一下JavaScript數(shù)組操作的常用API。相信對(duì)大家解決程序問題很有幫助。一、性

前言

相信大家都用慣了jquery或者underscore等這些類庫中常用的數(shù)組相關(guān)的操作,如$.isArray,_.some,_.find等等方法。這里無非是對(duì)原生js的數(shù)組操作多了一些包裝。
這里主要匯總一下JavaScript數(shù)組操作的常用API。相信對(duì)大家解決程序問題很有幫助。

一、性質(zhì)
JavaScript中的數(shù)組是一種特殊的對(duì)象,用來表示偏移量的索引是該對(duì)象的屬性,索引可能是整數(shù)。然而,這些數(shù)字索引在內(nèi)部被轉(zhuǎn)換為字符串類型,這是因?yàn)镴avaScript對(duì)象中的屬性名必須是字符串。

二、操作

1 判斷數(shù)組類型

var array0 = []; // 字面量
var array1 = new Array(); // 構(gòu)造器
// 注意:在IE6/7/8下是不支持Array.isArray方法的
alert(Array.isArray(array0));
// 考慮兼容性,可使用
alert(array1 instanceof Array);
// 或者
alert(Object.prototype.toString.call(array1) === '[object Array]');

2 數(shù)組與字符串

非常簡(jiǎn)單:由數(shù)組轉(zhuǎn)換為字符串,使用join;由字符串轉(zhuǎn)換為數(shù)組,使用split。

// join - 由數(shù)組轉(zhuǎn)換為字符串,使用join
console.log(['Hello', 'World'].join(',')); // Hello,World
// split - 由字符串轉(zhuǎn)換為數(shù)組,使用split
console.log('Hello World'.split(' ')); // ["Hello", "World"]

3 查找元素

相信大家都常用字符串類型indexOf,卻很少知道數(shù)組的indexOf同樣可以用于查找元素。

// indexOf - 查找元素
console.log(['abc', 'bcd', 'cde'].indexOf('bcd')); // 1
// 
var objInArray = [
 {
 name: 'king',
 pass: '123'
 },
 {
 name: 'king1',
 pass: '234'
 }
];
console.log(objInArray.indexOf({
 name: 'king',
 pass: '123'
})); // -1
var elementOfArray = objInArray[0];
console.log(objInArray.indexOf(elementOfArray)); // 0

從以上可以看出,對(duì)于數(shù)組包含對(duì)象的這種數(shù)組,indexOf方法并非是經(jīng)過深度比較來得到對(duì)應(yīng)的查找結(jié)果,僅僅是比較對(duì)應(yīng)元素的引用。

4 數(shù)組連接

使用concat,要注意,使用concat之后會(huì)生成一個(gè)新的數(shù)組。

var array1 = [1, 2, 3];
var array2 = [4, 5, 6];
var array3 = array1.concat(array2); // 實(shí)現(xiàn)數(shù)組連接之后,會(huì)創(chuàng)建出新的數(shù)組
console.log(array3);

5 類列表操作

用于添加元素,可分別使用push和unshift,移除元素可分別使用pop和shift。

// push/pop/shift/unshift
var array = [2, 3, 4, 5];
// 添加到數(shù)組尾部
array.push(6);
console.log(array); // [2, 3, 4, 5, 6]
// 添加到數(shù)組頭部
array.unshift(1);
console.log(array); // [1, 2, 3, 4, 5, 6]
// 移除最后一個(gè)元素
var elementOfPop = array.pop();
console.log(elementOfPop); // 6
console.log(array); // [1, 2, 3, 4, 5]
// 移除第一個(gè)元素
var elementOfShift = array.shift();
console.log(elementOfShift); // 1
console.log(array); // [2, 3, 4, 5]

6 splice方法

主要兩個(gè)用途:
① 從數(shù)組中間位置添加和刪除元素
② 從原有數(shù)組中,獲取一個(gè)新數(shù)組

當(dāng)然,兩個(gè)用途是一氣合成的,有些場(chǎng)景注重用途一,有些則注重用途二。

從數(shù)組中間位置添加和刪除元素,splice方法為數(shù)組添加元素,需提供如下參數(shù)
① 起始索引(也就是你希望開始添加元素的地方)
② 需要?jiǎng)h除的元素的個(gè)數(shù)或者是提取的元素的個(gè)數(shù)(添加元素時(shí)該參數(shù)設(shè)置為0)
③ 想要添加進(jìn)數(shù)組的元素

var nums = [1, 2, 3, 7, 8, 9];
nums.splice(3, 0, 4, 5, 6);
console.log(nums); // [1, 2, 3, 4, 5, 6, 7, 8, 9] 
// 緊接著做刪除操作或者提取新的數(shù)組
var newnums = nums.splice(3, 4);
console.log(nums); // [1, 2, 3, 8, 9]
console.log(newnums); // [4, 5, 6, 7]

7 排序

主要介紹reverse和sort兩個(gè)方法。數(shù)組反轉(zhuǎn)使用reverse,sort方法不僅可以用于簡(jiǎn)單排序,也可以用于復(fù)雜排序。

// 反轉(zhuǎn)數(shù)組
var array = [1, 2, 3, 4, 5];
array.reverse();
console.log(array); // [5, 4, 3, 2, 1]
我們先對(duì)字符串元素的數(shù)組進(jìn)行排序
var arrayOfNames = ["David", "Mike", "Cynthia", "Clayton", "Bryan", "Raymond"];
arrayOfNames.sort();
console.log(arrayOfNames); // ["Bryan", "Clayton", "Cynthia", "David", "Mike", "Raymond"]

我們對(duì)數(shù)字元素的數(shù)組進(jìn)行排序

// 如果數(shù)組元素時(shí)數(shù)字類型,sort()方法的排序結(jié)果就不能讓人滿意了
var nums = [3, 1, 2, 100, 4, 200];
nums.sort();
console.log(nums); // [1, 100, 2, 200, 3, 4]

sort方法是按照字典順序?qū)υ剡M(jìn)行排序的,因此它假定元素都是字符串類型,因此,即使元素是數(shù)字類型,也被認(rèn)為是字符串類型。這時(shí),可以在調(diào)用方法時(shí)傳入一個(gè)大小比較函數(shù),排序時(shí),sort()方法將會(huì)根據(jù)該函數(shù)比較數(shù)組中兩個(gè)元素的大小,從而決定整個(gè)數(shù)組的順序。

var compare = function(num1, num2) {
 return num1 > num2;
};
nums.sort(compare);
console.log(nums); // [1, 2, 3, 4, 100, 200]
var objInArray = [
 {
 name: 'king',
 pass: '123',
 index: 2
 },
 {
 name: 'king1',
 pass: '234',
 index: 1
 }
];
// 對(duì)數(shù)組中的對(duì)象元素,根據(jù)index進(jìn)行升序
var compare = function(o1, o2) {
 return o1.index > o2.index;
};
objInArray.sort(compare);
console.log(objInArray[0].index < objInArray[1].index); // true

8 迭代器方法

主要包含forEach和every、some和map、filter
forEach相信大家都會(huì),主要介紹一下其他四種方法。
every方法接受一個(gè)返回值為布爾類型的函數(shù),對(duì)數(shù)組中的每個(gè)元素使用該函數(shù)。如果對(duì)于所有的元素,該函數(shù)均返回true,則該方法返回true。

var nums = [2, 4, 6, 8];
// 不生成新數(shù)組的迭代器方法
var isEven = function(num) {
 return num % 2 === 0;
};
// 如果都是偶數(shù),才返回true
console.log(nums.every(isEven)); // true
some方法也接受一個(gè)返回值為布爾類型的函數(shù),只要有一個(gè)元素使得該函數(shù)返回true,該方法就返回true。
var isEven = function(num) {
 return num % 2 === 0;
};
var nums1 = [1, 2, 3, 4];
console.log(nums1.some(isEven)); // true

map和filter這兩個(gè)方法都可以產(chǎn)生新數(shù)組,map返回的新數(shù)組是對(duì)原有元素應(yīng)用某個(gè)函數(shù)得到的結(jié)果。如:

var up = function(grade) {
 return grade += 5;
}
var grades = [72, 65, 81, 92, 85];
var newGrades = grades.ma

filter方法和every方法很類似,傳入一個(gè)返回值為布爾類型的函數(shù)。和every()方法不同的是,當(dāng)對(duì)數(shù)組中的所有元素應(yīng)用該函數(shù),結(jié)果均為true時(shí),該方法并不返回true,而是返回一個(gè)新數(shù)組,該數(shù)組包含應(yīng)用該函數(shù)后結(jié)果為true的元素。

var isEven = function(num) {
 return num % 2 === 0;
};
var isOdd = function(num) {
 return num % 2 !== 0;
};
var nums = [];
for (var i = 0; i < 20; i++) {
 nums[i] = i + 1;
}
var evens = nums.filter(isEven);
console.log(evens); // [2, 4, 6, 8, 10, 12, 14, 16, 18, 20] 
var odds = nums.filter(isOdd);
console.log(odds); // [1, 3, 5, 7, 9, 11, 13, 15, 17, 19]

三、總結(jié)

以上還存在某些方法在低級(jí)瀏覽器不支持的問題,還需要再采用其他方法進(jìn)行兼容實(shí)現(xiàn)。

這些都是常見的可能大家不太容易想到的方法。大家不妨多留意一下。

希望本文所述對(duì)大家的javascript程序設(shè)計(jì)有所幫助。

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

JavaScript數(shù)組常用操作技巧

JavaScript數(shù)組常用操作技巧:前言相信大家都用慣了jquery或者underscore等這些類庫中常用的數(shù)組相關(guān)的操作,如$.isArray,_.some,_.find等等方法。這里無非是對(duì)原生js的數(shù)組操作多了一些包裝。這里主要匯總一下JavaScript數(shù)組操作的常用API。相信對(duì)大家解決程序問題很有幫助。一、性
推薦度:
標(biāo)簽: 設(shè)置 操作 方法
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top