기사 디렉토리
ES6의 Array.group()은 결합된 배열을 빠르게 정렬합니다.
1. 바벨에 의존해야 합니다. 먼저 프로젝트에 바벨을 설치하세요.
npm i core-js
2. 소개
import 'core-js/actual/array/group
3. 적용 시나리오
배열의 특정 정보에 따라 그룹화해야 하는 배열이 있습니다.
예:
지방에 따라 그룹화될 고객 정보 그룹이 있습니다.
4. 신청
해결할 코드 한 줄
const orderList = [{
nickName: 'steven',
productName: '西瓜',
price: 29,
province: 'henan',
},{
nickName: '对方的',
productName: '杨梅',
price: 22,
province: 'shanxi',
},{
nickName: '范电池',
productName: '苹果',
price: 19,
province: 'dongbei',
},{
nickName: '调查v',
productName: '桃子',
price: 88,
province: 'shanxi',
},{
nickName: '2号',
productName: '桃子',
price: 88,
province: 'shanxi',
}]
const group=orderList.group(({
province})=>province)
console.log(group)
5. 미사용시 구현
const provinceObj = {
}
for (let index = 0; index < orderList.length; index++) {
const element = orderList[index]; //循环的该条数据 对象
const provinceKey = element.province //该条数据中的省字段
// 判断空对象中是否有该属性,有key值存在就push
if (provinceObj[provinceKey]) {
provinceObj[provinceKey].push(element)
} else {
// key值不存在就新建一个key和value
provinceObj[provinceKey] = [element] //[element] 将该条数据放进数组
}
}
console.log(provinceObj)
같은 결과