js根據(jù)需要計算數(shù)組中重復(fù)出現(xiàn)某個元素的個數(shù)
一、有時候的根據(jù)需要需要計算數(shù)組中某個元素重復(fù)出現(xiàn)的個數(shù)
var arr = ["apple","orange","apple","orange","pear","orange"];
計算出來重復(fù)出現(xiàn)的元素個數(shù):{apple: 2, orange: 3, pear: 1}
二、代碼實現(xiàn)
//統(tǒng)計一個數(shù)組中有多少個不重復(fù)的單詞:
// 不用reduce時:
var arr = ["apple","orange","apple","orange","pear","orange"];
function getWordCnt(){
var obj = {};
for(var i= 0, l = arr.length; i< l; i++){
var item = arr[i];
obj[item] = (obj[item] +1 ) || 1;
}
return obj;
}
console.log(getWordCnt());//{apple: 2, orange: 3, pear: 1}
// 用reduce時:
var arr = ["apple","orange","apple","orange","pear","orange"];
function getWordCnt(){
return arr.reduce(function(prev,next){
prev[next] = (prev[next] + 1) || 1;
return prev;
},{});
}
console.log(getWordCnt());//{apple: 2, orange: 3, pear: 1}
補充知識點:
若查詢對象中某個屬性沒有,可自行為其添加
var muziObj = {};
muziObj['name'] = 'muzidigbig';
muziObj.age = 21;
console.log(muziObj)//{name: "muzidigbig", age: 21}
若有不足請多多指教!希望給您帶來幫助!
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
相關(guān)文章
js監(jiān)聽滾動條滾動事件使得某個標(biāo)簽內(nèi)容始終位于同一位置
js如何監(jiān)聽滾動條滾動事件,使得某個標(biāo)簽內(nèi)容始終位于同一位置,下面有個不錯的示例,大家可以參考下2014-01-01
JS的replace方法與正則表達式結(jié)合應(yīng)用講解
replace方法的語法是:stringObj.replace(rgExp, replaceText) 其中stringObj是字符串(string),reExp可以是正則表達式對象(RegExp)也可以是字符串(string),replaceText是替代查找到的字符串。。為了幫助大家更好的理解,下面舉個簡單例子說明一下2007-12-12
bootstrap 路徑導(dǎo)航 分頁 進度條的實例代碼
本文通過實例代碼給大家介紹了bootstrap 路徑導(dǎo)航 分頁 進度條的相關(guān)知識,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-08-08

