javascript 中關(guān)于array的常用方法
最近總結(jié)了一些關(guān)于array中的常用方法,
其中大部分的方法來(lái)自于《JavaScript框架設(shè)計(jì)》這本書(shū),
如果有更好的方法,或者有關(guān)于string的別的常用的方法,希望大家不吝賜教。
第一部分
數(shù)組去重,總結(jié)了一些數(shù)組去重的方法,代碼如下:
/** * 去重操作,有序狀態(tài) * @param target * @returns {Array} */function unique(target) { let result = []; loop: for (let i = 0,n = target.length;i < n; i++) { for (let x = i + 1;x < n;x++) { if (target[x] === target[i]) { continue loop; } } result.push(target[i]); } return result;}/** * 去重操作,無(wú)序狀態(tài),效率最高 * @param target * @returns {Array} */function unique1(target) { let obj = {}; for (let i = 0,n = target.length; i < n;i++) { obj[target[i]] = true; } return Object.keys(obj);}/** * ES6寫法,有序狀態(tài) * @param target * @returns {Array} */function unique2(target) { return Array.from(new Set(target));}function unique3(target) { return [...new Set(target)];}第二部分
數(shù)組中獲取值,包括最大值,最小值,隨機(jī)值。
/** * 返回?cái)?shù)組中的最小值,用于數(shù)字?jǐn)?shù)組 * @param target * @returns {*} */function min(target) { return Math.min.apply(0,target);}/** * 返回?cái)?shù)組中的最大值,用于數(shù)字?jǐn)?shù)組 * @param target * @returns {*} */function max(target) { return Math.max.apply(0,target);}/** * 從數(shù)組中隨機(jī)抽選一個(gè)元素出來(lái) * @param target * @returns {*} */function random(target) { return target[Math.floor(Math.random() * target.length)];}第三部分
對(duì)數(shù)組本身的操作,包括移除值,重新洗牌,扁平化和過(guò)濾不存在的值
/** * 移除數(shù)組中指定位置的元素,返回布爾表示成功與否 * @param target * @param index * @returns {boolean} */function removeAt(target,index) { return !!target.splice(index,1).length;}/** * 移除數(shù)組中第一個(gè)匹配傳參的那個(gè)元素,返回布爾表示成功與否 * @param target * @param item * @returns {boolean} */function remove(target,item) { const index = target.indexOf(item); if (~index) { return removeAt(target,index); } return false;}/** * 對(duì)數(shù)組進(jìn)行洗牌 * @param array * @returns {array} */function shuffle(array) { let m = array.length, t, i; // While there remain elements to shuffle… while (m) { // Pick a remaining element… i = Math.floor(Math.random() * m--); // And swap it with the current element. t = array[m]; array[m] = array[i]; array[i] = t; } return array;}/** * 對(duì)數(shù)組進(jìn)行平坦化處理,返回一個(gè)一維的新數(shù)組 * @param target * @returns {Array} */function flatten (target) { let result = []; target.forEach(function(item) { if(Array.isArray(item)) { result = result.concat(flatten(item)); } else { result.push(item); } }); return result;}/** * 過(guò)濾屬性中的null和undefined,但不影響原數(shù)組 * @param target * @returns {Array.<T>|*} */function compat(target) { return target.filter(function(el) { return el != null; })}
新聞熱點(diǎn)
疑難解答
圖片精選