JS从非数组对象转数组的方法小结


Posted in Javascript onMarch 26, 2018

前言

本文主要汇总了一些JS从非数组对象转数组的方法,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

Array.prototype.slice.call(obj)

该方法可以将类数组对象转换为数组,所谓类数组对象,就是含 length 和索引属性的对象

返回的数组长度取决于对象 length 属性的值,且非索引属性的值,或索引大于 length 的值都不会被返回到数组中

实锤如下

let obj = {
 '0': 3,
 '1': 13,
 '2': 23,
 '3': 33,
 'length': 3,
 'name': 330
}
let arr = Array.prototype.slice.call(obj)
// [3, 13, 23]

简洁写法 [].slice.call(obj)

Array.from(obj)

该方法可以将类数组对象和可迭代对象转换为数组

类数组对象上文已提及,何为可迭代对象?

  • Array、Set、Map 和字符串都是可迭代对象(WeakMap/WeakSet 并不是可迭代对象)
  • 字符串变成了可迭代对象,解决了编码的问题
  • 这些对象都有默认的迭代器,即具有 Symbol.iterator 属性
  • 可以用 for of 循环
  • 所有通过生成器创建的迭代器都是可迭代对象
  • document.getElementsByTagName("div") 返回的是可迭代对象但不是一个数组
    Array.isArray(document.getElementsByTagName('div')) 返回 false

通过生成器创建可迭代对象

let obj = {
 '0': 3,
 '1': 13,
 '2': 23,
 '3': 33
}

function *createIterator(obj){
 for(let value in obj){
  yield obj[value]
 }
}

let iterator = createIterator(obj)
let arr = Array.from(iterator)
// [3, 13, 23, 33]

改造对象本身,使其成为可迭代对象

默认情况下,开发者定义的对象都是不可迭代对象,但如果给 Symbol.iterator 属性添加一个生成器,则可以将其变为可迭代对象

let obj = {
 '0': 3,
 '1': 13,
 '2': 23,
 '3': 33
}

obj[Symbol.iterator] = function* () {
 for(let value in this){
  yield this[value]
 }
}

let arr = Array.from(obj)
// [3, 13, 23, 33]

判断对象是否为可迭代对象的方法

typeof obj[Symbol.iterator] === 'function'

一点延伸 for of 与 forEach 与 for in

for of 用于循环可迭代对象,包括有 Array, Set, Map, 字符串

而 Array, Set, Map 都有 forEach 方法

另外,NodeList 不是 Array, Set, Map,但是一个可迭代对象,可以用 for of 遍历

此外,用 for of 循环对象时可以通过 break 提前终止,而 forEach 无法提前跳出循环

for in 遍历对象的可枚举属性,包括其原型链上的属性,且不保证顺序

若要遍历对象自身的可枚举属性,使用 hasOwnProperty() 方法来确定属性是否时对象自身属性

Object.getOwnPropertyNames(obj) , 返回对象自身可枚举或不可枚举属性

反正已经扯远了,那就再扯远一点, Object.assign() 方法将所有可枚举属性的值从一个或多个源对象复制到目标对象

[…obj]

展开运算符可以将可迭代对象转换为数组

例如, [...'obj'] 返回 ["o", "b", "j"]

字符串去重

[...new Set('objobj')]

Object.values(obj)

默认情况下,开发者定义的对象都是不可迭代对象,但提供了返回迭代器的方法

  • entries()
  • values()
  • keys()

通过使用这些方法,可以返回相关的数组

与类数组对象需要对象有 length 值不同,Object.values(obj) 返回对象自身可枚举属性值的集合

let obj = {
 '0': 3,
 '1': 13,
 '2': 23,
 '3': 33
}
let arr = Object.values(obj) // [3, 13, 23, 33]

字符串与数组的关系

在很大程度上,可以将字符串看成字符串数组,

都有 length 属性

都有 concat() / indexOf() / includes() / slice() 方法

不过值得注意的是, string 上没有方法可以原地修改它自身的内容,都是返回新的 string

string 还有个 repeat() 方法,创建指定数量的字符串副本

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
很好用的js日历算法详细代码
Mar 07 Javascript
使用GruntJS链接与压缩多个JavaScript文件过程详解
Aug 02 Javascript
简单谈谈node.js 版本控制 nvm和 n
Oct 15 Javascript
JS实现带提示的星级评分效果完整实例
Oct 30 Javascript
极易被忽视的javascript面试题七问七答
Feb 15 Javascript
EasyUI闪屏EasyUI页面加载提示(原理+代码+效果图)
Feb 21 Javascript
基于javascript实现精确到毫秒的倒计时限时抢购
Apr 17 Javascript
node.js请求HTTPS报错:UNABLE_TO_VERIFY_LEAF_SIGNATURE\的解决方法
Dec 18 Javascript
详解vue父子组件间传值(props)
Jun 29 Javascript
vue.js 实现图片本地预览 裁剪 压缩 上传功能
Mar 01 Javascript
微信小程序自定义弹窗wcPop插件
Nov 19 Javascript
JavaScript实现世界各地时间显示
Sep 07 Javascript
深入理解Node module模块
Mar 26 #Javascript
利用Console来Debug的10个高级技巧汇总
Mar 26 #Javascript
关于vuejs中v-if和v-show的区别及v-show不起作用问题
Mar 26 #Javascript
vue中使用iview自定义验证关键词输入框问题及解决方法
Mar 26 #Javascript
Vue中v-show添加表达式的问题(判断是否显示)
Mar 26 #Javascript
使用Vue构建可重用的分页组件
Mar 26 #Javascript
基于jQuery实现Ajax验证用户名是否可用实例
Mar 25 #jQuery
You might like
阿拉伯的咖啡与水烟
2021/03/03 咖啡文化
CodeIgniter CLI模式简介
2014/06/17 PHP
php实现mysql数据库分表分段备份
2015/06/18 PHP
thinkPHP基于ajax实现的菜单与分页示例
2016/07/12 PHP
jQuery EasyUI API 中文文档 - TimeSpinner时间微调器
2011/10/23 Javascript
IE事件对象(The Internet Explorer Event Object)
2012/06/27 Javascript
js模式化窗口问题![window.dialogArguments]
2016/10/30 Javascript
laydate.js日期时间选择插件
2017/01/04 Javascript
详解Vue.js分发之作用域槽
2017/06/13 Javascript
利用SpringMVC过滤器解决vue跨域请求的问题
2018/02/10 Javascript
React学习笔记之高阶组件应用
2018/06/02 Javascript
在vue中动态修改css其中一个属性值操作
2020/12/07 Vue.js
vue的hash值原理也是table切换实例代码
2020/12/14 Vue.js
Django中实现点击图片链接强制直接下载的方法
2015/05/14 Python
详解python并发获取snmp信息及性能测试
2017/03/27 Python
利用Tkinter和matplotlib两种方式画饼状图的实例
2017/11/06 Python
Python:Scrapy框架中Item Pipeline组件使用详解
2017/12/27 Python
python读取Excel实例详解
2018/08/17 Python
Python读入mnist二进制图像文件并显示实例
2020/04/24 Python
Pycharm制作搞怪弹窗的实现代码
2021/02/19 Python
皇马官方商城:Real Madrid Store
2016/09/02 全球购物
设计师家具购买和委托在线市场:Viyet
2016/11/16 全球购物
Napapijri西班牙在线商店:夹克、外套、运动衫等
2020/11/05 全球购物
导游实习生自荐书
2014/01/28 职场文书
人力资源主管岗位职责
2014/01/29 职场文书
优秀士兵先进事迹
2014/02/06 职场文书
工作表现自我评价
2014/02/08 职场文书
《蒲公英》教学反思
2014/02/28 职场文书
世界红十字日活动总结
2015/02/10 职场文书
会计试用期自我评价
2015/03/10 职场文书
新闻稿件写作范文
2015/07/18 职场文书
校园之声广播稿
2015/08/18 职场文书
解决MultipartFile.transferTo(dest) 报FileNotFoundExcep的问题
2021/07/01 Java/Android
用python基于appium模块开发一个自动收取能量的小助手
2021/09/25 Python
分享python函数常见关键字
2022/04/26 Python
vue使用element-ui按需引入
2022/05/20 Vue.js