第一種方法使用reduce方法,通過傳入的內容來確定 var arrs=['a','a','d','c','f','d','我','我','他',2,2,5,4,6,8]; function a(){ return arrs.reduce( function(prev:any,next:any){ console.log(prev); console.log(next); prev[next]=(prev[next]+1) || 1; return prev; },{}) } console.log(a()); 第二種 雙重循環(huán)對比法 實現(xiàn)理論:定義一個空數(shù)組,第一個循環(huán)循環(huán)數(shù)組,然后創(chuàng)建一個變量存放當前值,然后再創(chuàng)建一個變量存放出現(xiàn)次數(shù),第二個循環(huán)跟第一個循環(huán)的數(shù)據(jù)進行對比,如果存在次數(shù)變量就加1,對比過的讓他的值變成-1,最后當前值不不等于-1.存入新的數(shù)組 var arr=['a','a','d','c','f','d','我','我','他',2,2,5,4,6,8];
function arrCheck(arr:any){ var newArr = []; for(var i=0;i<arr.length;i++){ var temp=arr[i]; var count=0; for(var j=0;j<arr.length;j++){ if(arr[j]==temp){ count++; arr[j]=-1; } } if(temp != -1){ newArr.push(temp+","+count) } } return newArr; } arrCheck(arrs); 第三種,最簡單 實現(xiàn)理論: 定義一個空對象,循環(huán)這個數(shù)組,判斷如果對象里面有這個屬性就給這個值加1(使用hasOwnProperty),沒有呢就把這個屬性添加到這個對象中,設置初始值為1 var arr=['a','a','d','c','f','d','我','我','他',2,2,5,4,6,8]; var obj={}; for(let i=0;i<arr.length;i++){ if(obj.hasOwnProperty(arr[i])){ obj[arr[i]] +=1; }else{ obj[arr[i]] =1; } } console.log(obj);
|
|