JS中对象转数组的几种方法

技术知识
0 1605
小师傅 小师傅2020-07-08
积分:2397

1.Array.from() 方法,用于数组的浅拷贝。就是将一个类数组对象或者可遍历对象转换成一个真正的数组。

代码如下:

let obj = {
        0: 'nihao',
        1: 'haha',
        2: 'gansha',
        'length': 3
    } 
let arr = Array.from(obj)
console.log(arr);

1.png

tips: 1. object中必须有length属性,返回的数组长度取决于length长度 
        2.key 值必须是数值

 

2.Object.values(object)
tips:与第一种不同的是不需要length属性,返回一个对象所有可枚举属性值


这里简单说一下可枚举性。目前我还没理解这个可枚举性有什么用,大概意思就是

对象的每一个属性都有一个描述对象,用来描述和控制该属性的行为,用Object.getOwnPropertyDescriptor方法来获取该描述对象(用Object.defineProperty方法来设置)。

以后仔细研究之后会再好好写写这个可枚举性的!

代码如下:

let obj = {
        0: 'nihao',
        1: 'haha',
        2: 'gansha',
    }
let arr = Object.values(obj)
console.log(arr);

1.png

3.Object.keys(object)
tips:返回一个对象的自身可枚举属性组成的数组,数组中属性名的排列顺序和使用 for…in 循环遍历该对象时返回的顺序一致

代码如下:

let obj = {
        0: 'nihao',
        1: 'haha',
        2: 'gansha',
    }
let arr = Object.keys(obj)
console.log(arr);

3.png

4.Object.entries(object)
tips:返回一个给定对象自身可枚举属性的键值对数组

代码如下:

let obj = {
        0: 'nihao',
        1: 'haha',
        2: 'gansha',
    }
let arr = Object.entries(obj)
console.log(arr);


4.png

5.for  in 循环

精选帖子
Android 可可影视 v3.3.6无广告纯净版 1765
Android QQ音乐 v11.3.7 定制版解锁免费听歌无广告版 2199
Android 草图大师SKP v1.5 解锁会员版 7647
Android OmoFun追漫神器 v4.2.1 无广告绿色版 4651
AdobeGenP Adobe全家桶系列激活工具 v3.5.0/3.4.14.1 绿色版 5231
Android 七猫免费听书 v1.4 解锁高级版 3689
超良心的抢票神器——Bypass1.16 3242
Android 玲珑加速器 v6.10.9.40 解锁无限时间 2068
Android 大师兄影视 v3.3.8 去广告会员版 1191
热门帖子
玫瑰克隆,一键爆款工具详细介绍和使用教程,自媒体必备 304
好用的梯子软件推荐-稳定好用的手机梯子软件+电脑好用的梯子及外网加速器指南(免费试用升级付费) 222
多多虚拟类目新玩法:机器人全程帮助发货和回客服,轻松实现月入1-5W目标 194
玫瑰克隆,自媒体必备,一键爆款工具详细介绍和使用教程 164
电脑EA策略挂机项目单窗口收益20-30u,单电脑可挂5-10个窗口收益稳健4位数 109
Android 静读天下 v10.3(1003000) 免广告付费专业版 88
2025年最新番茄音乐人挂机项目,每天几分钟,月入1000+,可矩阵,一台电脑支持多个账号 58
稳定运行两年的游戏自动挖金项目,日入千元,永不失业的副业! 58
看广新平台,不乱弹窗口,单机做到了70加,支持苹果和安卓可批量,做到了日入1万+ 46