数组的去重、获取下标、删除、添加等各种操作

1.数组去除空值

function filter_array(array) {  
  return array.filter(item=>item); 
} 
//JS
var t = [false, null, 0, NaN, undefined, "",'aaaa']; 
t.filter(function (item) { return item });
t.filter(function (item) { return item.IsCurrent == true;}

2.通过某元素获取在数组中对应的下标(也是判断是否存在于这个数组中)

//ES6
var t = [{id:1},{id:2},{id:3}]; 
var tt = {id:3}; 
t.map(item => item.id ).indexOf(tt.id)
//JS
var t = [{id:1},{id:2},{id:3}]; 
var tt = {id:3}; 
t.map(function (item) { return item.id}).indexOf(tt.id)

3.改变数组对象中元素的值

//JS
var t = [{id:1},{id:2},{id:3}]; 
t.map(function (item) { return item.id = 55})

4.数组去重

let arr = [1,2,3,4,4,1]
let newArr = arr.reduce((pre,cur)=>{
    if(!pre.includes(cur)){
      return pre.concat(cur)
    }else{
      return pre
    }
},[])
console.log(newArr);// [1, 2, 3, 4]

5.计算数组中每个元素出现的次数

let names = ['Alice', 'Bob', 'Tiff', 'Bruce', 'Alice'];

let nameNum = names.reduce((pre,cur)=>{
  if(cur in pre){
    pre[cur]++
  }else{
    pre[cur] = 1 
  }
  return pre
},{})
console.log(nameNum); //{Alice: 2, Bob: 1, Tiff: 1, Bruce: 1}

6.对象里的属性求和

var result = [
    {
        subject: 'math',
        score: 10
    },
    {
        subject: 'chinese',
        score: 20
    },
    {
        subject: 'english',
        score: 30
    }
];

var sum = result.reduce(function(prev, cur) {
    return cur.score + prev;
}, 0);
console.log(sum) //60
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 天冷心不冷。 晚上逛逛北京,很俗地在天安门拍了张自拍。 没什么了。
    可樂鳮翅阅读 1,279评论 0 0
  • 所有的感受就想一条河流,如果我们压抑感受就像在河流中筑堤截流,就会出现抑郁。必须让所有的感受流动起来,流经我们...
    誼君阅读 1,522评论 0 0
  • 最近要毕业了,心里有道不出摸不清的情绪,不管是对学校的不舍,还是对未来的迷茫,甚至是对于社会的恐惧,错综复杂,百...
    L渡阅读 1,148评论 0 0
  • 有趣 初晓 隔了昏晓 是从月色开始 霞光在山的那边褪去 众星也悄然的点缀了穹 我问从远方而...
    随半阅读 2,256评论 0 3
  • 某日刷微博刷到一个话题话题,大概是说喝醉后你们都干了些什么蠢事? 赞数最多的第一条评论是一个妹子发的一句话,一张图...
    小李子q阅读 5,454评论 6 35

友情链接更多精彩内容