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 相关文章推荐
javascript跨域刷新实现代码
Jan 01 Javascript
基于jquery的下拉框改变动态添加和删除表格实现代码
Sep 12 Javascript
jquery实现瀑布流效果分享
Mar 26 Javascript
JavaScript常用小技巧小结
Dec 29 Javascript
jQuery+formdata实现上传进度特效遇到的问题
Feb 24 Javascript
JavaScript中setTimeout和setInterval函数的传参及调用
Mar 11 Javascript
jQuery图片轮播插件——前端开发必看
May 31 Javascript
js仿QQ邮箱收件人选择与搜索功能
Feb 10 Javascript
手淘flexible.js框架使用和源代码讲解小结
Oct 15 Javascript
vue中利用simplemde实现markdown编辑器(增加图片上传功能)
Apr 29 Javascript
小程序实现按下录音松开识别语音
Nov 22 Javascript
vue+elementUI实现简单日历功能
Sep 24 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
Trying to clone an uncloneable object of class Imagic的解决方法
2012/01/11 PHP
php简单计算页面加载时间的方法
2015/06/19 PHP
用PHP代码在网页上生成图片
2015/07/01 PHP
php经典算法集锦
2015/11/14 PHP
php pthreads多线程的安装与使用
2016/01/19 PHP
CodeIgniter钩子用法实例详解
2016/01/20 PHP
docker-compose部署php项目实例详解
2019/07/30 PHP
JavaScript入门教程(8) Location地址对象
2009/01/31 Javascript
字段太多jquey快速清空表单内容方法
2014/08/21 Javascript
取得元素的左和上偏移量的方法
2014/09/17 Javascript
angularjs学习笔记之简单介绍
2015/09/26 Javascript
jquery制做精致的倒计时特效
2016/06/13 Javascript
jquery常用的12个小功能
2016/07/22 Javascript
JS实现页面内跳转的简单代码
2017/09/03 Javascript
讲解vue-router之什么是嵌套路由
2018/05/28 Javascript
Angular PWA使用的Demo示例
2019/01/31 Javascript
基于vue-draggable 实现三级拖动排序效果
2020/01/10 Javascript
js+canvas实现简单扫雷小游戏
2021/01/22 Javascript
vue+Element-ui实现分页效果
2020/11/15 Javascript
[43:35]EG vs Winstrike 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
Python标准库内置函数complex介绍
2014/11/25 Python
Python中对数组集进行按行打乱shuffle的方法
2018/11/08 Python
python+opencv实现霍夫变换检测直线
2020/10/23 Python
python操作文件的参数整理
2019/06/11 Python
Softmax函数原理及Python实现过程解析
2020/05/22 Python
Python如何输出整数
2020/06/07 Python
基于python实现复制文件并重命名
2020/09/16 Python
食堂标语大全
2014/06/11 职场文书
公司法定代表人授权委托书
2014/09/29 职场文书
房屋转让协议书
2014/10/18 职场文书
2014年公司工作总结
2014/11/22 职场文书
综合测评个人总结
2015/03/03 职场文书
2015年组织部工作总结
2015/04/03 职场文书
2019大学生实习报告
2019/06/21 职场文书
MySQL如何使用使用Xtrabackup进行备份和恢复
2021/06/21 MySQL
Python中三种花式打印的示例详解
2022/03/19 Python