情景1:如何把一个对象{'未完成':5, '已完成':8, '待确认':4, '已取消':6}转为[{"未完成":5},{"已完成":8},{"待确认":4},{"已取消":6}]
对象的两种取值方式
我们都知道,JS中对象有两种取值方式,通过在.后面直接加属性名取值,这也是我们最常使用的一种方式,例如:
let obj = {name: 'wan'};
console.log(obj.name); //wan
这是最普通的一种方式,还有一种方式我们用的不太多,就是使用[]包住属性名取值,类似于数组那样,例如
let obj = {name: 'wan'};
console.log(obj[name]); //wan
那二者之前有什么区别呢,如果对于一个已知的对象来说,几乎是没什么区别的,但是如果我们需要的对象的key是变量呢?这就回到了我们文章开始是提到的问题,如何将一个对象转化为数组
将对象转化为数组
我们文章开始例子中的对象是
let obj = {'未完成':5, '已完成':8, '待确认':4, '已取消':6};
如果目标数组只是为了得到对象的key的集合或者value的集合还是相对容易的
var arr = []
for (let i in obj) {
arr.push(obj[i]); //属性
//arr.push(obj[i]); //值
}
console.log(arr);
如果像我文中开始的需求的话就只需要改变一下push进去的内容为一个对象即可
var arr = [] for (let i in obj) { let o = {}; o[i] = obj[i]; arr.push(o) } console.log(arr);
情景2:
const arr1 =[{p:1},{p:2},{p:3}] const arr2 =[{name:'a1',data:'12'},{name:'a1',data:'12',age:23},{name:'a1',data:'12',sex:'1'}] arr3 =[{name:'a1',data:'12','p':1},{name:'a1',data:'12',age:23,'p':2},{name:'a1',data:'12',sex:'1','p':3}] 将arr1 arr2 变成arr3 arr1.map((item,index) => ({ ...item, ...arr2[index] })) 即可
附注:理解for-in for-of 的用法
for in
let obj ={'未完成':2,'已完成':3,'待确认':2,'已取消':8}
let arr = []
for(let i in obj){
// arr.push(obj[i])//[2,3,2,8]
// arr.push(i)//["未完成", "已完成", "待确认", "已取消"]
}
console.log('将对象中的值或者属性放入一个数组中',arr)
for of
let obj =[{"未完成":1}, {"已完成":2}, {"待确认":7}, {"已取消":9}]
let arr = []
for(let i of obj){//i 代表每一个{} 遍历数组
for(let j in i){//j代表属性值 遍历对象
console.log('j',j)
arr[j] =i[j]
}
}
情景3:
最终数据结构:
let str ='[{"nameCn":"学员姓名","nameEn":"name","data":""},{"nameCn":"联系方式","nameEn":"mobile","data":""}]' const arr = [{'lable':'头像','prop':'img'},{'lable':'支付方式','prop':'methods'},{'lable':'年龄','prop':'sex'}] let arr1 =JSON.parse(str) for(let i of arr1){ arr.push({ 'lable':i.nameCn, 'prop':i.nameEn }) }
情景4:
let results=[ {'name':'shijiali','age':'23','gender':'本科','extra':'[{"nameCn":"学员姓名","nameEn":"name","data":""},{"nameCn":"联系方式","nameEn":"mobile","data":""}]'}, {'name':'shijiali1','age':'23','gender':'本科','extra':'[{"nameCn":"学员姓名","nameEn":"name","data":""},{"nameCn":"联系方式","nameEn":"mobile","data":""}]'}, {'name':'shijial2','age':'23','gender':'本科','extra':'[{"nameCn":"学员姓名","nameEn":"name","data":""},{"nameCn":"联系方式","nameEn":"mobile","data":""}]'} ] // let arr = JSON.parse(results.) results.forEach(item=>{ let arr= JSON.parse(item.extra) arr.forEach(val=>{ item[val.nameEn]=val.data }) })
情景5:
const hours ='1,2,3,4,5,6' const pv ="122312,3435,5657,768768,7567,2323" const uv ="12,23,32,21,23,33" let arr_h =hours.split(",")//字符串转化为数组 join(‘’) 数组转化为字符串 console.log('arr_h',arr_h) let arr_p =pv.split(',') let arr_u =uv.split(',') let arr=[] arr_h.forEach((item,index)=>{ arr.push({ hours:item, pv:arr_p[index], uv:arr_u[index] }) })