博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JS中将对象转化为数组
阅读量:5878 次
发布时间:2019-06-19

本文共 974 字,大约阅读时间需要 3 分钟。

前言

其实这本来应该是一个很基础的问题了,但我之做一想记录一下是因为之前因为对象转数组的时候卡住了后来弄了出来,但最近再遇到这个问题时竟然又卡主了,所以,关于这个问题,如何把一个对象{'未完成':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);

后记

说到底还是思维不够灵活在解决问题时就卡克了,说实话这不是一个什么难题,但是把自己思维限制死了之后就会觉得是个难题,谨记!

转载于:https://www.cnblogs.com/wancheng7/p/8735168.html

你可能感兴趣的文章
考拉消息中心消息盒子处理重构(策略模式)
查看>>
so easy 前端实现多语言
查看>>
【追光者系列】HikariCP源码分析之ConcurrentBag&J.U.C SynchronousQueue、CopyOnWriteArrayList...
查看>>
kafka之旅总览
查看>>
【2018年最新】iOS面试题之第三方框架
查看>>
拼音工具类PinyinUtils
查看>>
Compose函数作用
查看>>
获取url中参数
查看>>
[译] 别再对 Angular 表单的 ControlValueAccessor 感到迷惑
查看>>
在navicat中如何新建连接数据库
查看>>
canvas系列教程05-柱状图项目3
查看>>
Kotlin 之旅4 面向对象
查看>>
Android NDK开发之旅11 JNI 数组的处理
查看>>
什么是机器学习
查看>>
Rxjs实践-各种排序算法排序过程的可视化展示
查看>>
css绘制几何图形
查看>>
键盘鼠标共享效率工具-Synergy
查看>>
iOS逆向之旅(进阶篇) — 工具(class-dump)
查看>>
CocoaPods安装指南
查看>>
认识并使用 Promise
查看>>