JS小功能

Es6

js对数组进行分类

const people = [
  { name: 'Alice', age: 21 },
  { name: 'Max', age: 20 },
  { name: 'Jane', age: 20 }
]

const groupedPeople = {
  20: [
    { name: 'Max', age: 20 },
    { name: 'Jane', age: 20 }
  ],
  21: [
    { name: 'Alice', age: 21 }
  ]
}

function groupBy(objectArray, property) {
  return objectArray.reduce(function (acc, obj) {
    let key = obj[property]
    if (!acc[key]) {
      acc[key] = []
    }
    acc[key].push(obj)
    return acc
  }, {})
}
 
const groupedPeople = groupBy(people, 'age')
// groupedPeople is:
// {
//   20: [
//     { name: 'Max', age: 20 },
//     { name: 'Jane', age: 20 }
//   ],
//   21: [
//    { name: 'Alice', age: 21 }
//   ]
// }

js比较两个数组是否相同

JSON.stringify([1,2,3].sort()) === JSON.stringify([3,2,1].sort());  //true
[1,2,3].sort().toString() === [3,2,1].sort().toString();  //true

// 判断数组值是否相等
isAllEqual (array) {
  if (array.length > 0) {
    return !array.some(function (value, index) {
      // [1, 2, 3].sort().toString() === [2, 1, 3].sort().toString()  // true
      return value.sort().toString() !== array[0].sort().toString()
    })
  }
  return true
}

对象去重

d 对象去重在这里插入图片描述

数组去重

在这里插入图片描述

数组map

在这里插入图片描述

将数组打乱*

 arr.sort( () => Math.random() - 0.5)

sort

在这里插入图片描述

排序字母或汉字

const arr = ['我', '小', '大', '车']
const value = arr.sort((a, b) => {
	return b.localCompare(a)
})

在这里插入图片描述

通过数据匹配相应的数据

const arr = [3, 1]

const obj = [
  { id: 1, name: 'hahah' },
  { id: 2, name: 'wwww' },
  { id: 3, name: 'xxxx' },
]

const newArr = []
for (let item of arr) {
  for (let options of obj) {
    if (options.id == item) {
      newArr.push(options)
    }
  }
}
console.log('newArr', newArr)

改变数据的key值


 let data = [{

    "adcode": "110100",

    "city": "北京市",

    "id": 234
  }, {

    "adcode": "120100",

    "city": "天津市",

    "id": 235,
    "child": [
      {

        "adcode": "110100",

        "city": "北京市",

        "id": 234
      }, {

        "adcode": "110100",

        "city": "北京市",

        "id": 234
      },
    ]

  }]//旧key到新key的映射

  let keyMap = {
    "adcode": "value",
    "city": "name"
  }

  function tt(data) {
    data.forEach(item => {
      let obj = item
      for (let key in obj) {
        let newKey = keyMap[key]
        if (newKey) {
          obj[newKey] = obj[key]
          delete obj[key]
        }
      }
      if (item.child) {
        tt(item.child)
      }
    })
    return data
  }

  console.log(tt(data))
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值