情景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]
        })

     })

  

 

posted on 2019-08-30 16:01  白不了的黑发  阅读(497)  评论(0编辑  收藏  举报