当前位置:首页 > javascript技术文章 > JS从非数组对象转数组的方法小结

汇总JS从非数组对象转数组的方法

  • 发布时间:
  • 作者:码农之家原创
  • 点击:59

这篇文章主要知识点是关于js、数组对象、数组、的内容,如果大家想对相关知识点有系统深入的学习,可以参阅以下电子书

JavaScript核心技术开发解密
  • 类型:JavaScript大小:68.4 MB格式:PDF作者:阳波
立即下载

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

前言

本文主要汇总了一些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() 方法,创建指定数量的字符串副本

总结

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

以上就是本次给大家分享的关于java的全部知识点内容总结,大家还可以在下方相关文章里找到相关文章进一步学习,感谢大家的阅读和支持。

推荐内容

怎样利用Tensorflow构建自己的图片数据集TFrecords

python reverse反转部分数组详解

python把京东订单推送到测试环境,提供便利操作步骤

示例讲解php+mysql查询实现无限下级分类树输出

深入理解Java泛型的概念、定义与运行方法

展开 +

收起 -

javascript 相关电子书
学习笔记
网友NO.651384

js 用于检测类数组对象的函数方法

如下所示: //判定o是否是一个类数组对象//字符串和函数有length属性,但是它们//可以用typeof检测将其排除。在客户端JavaScript中,DOM文本节点//也有length属性,需要用额外判断o.nodeType!=3将其排除function isArrayLike(o){ if(o//o非null/undefined等 typeof o==="object"//o是对象 isFinite(o.length)//o.length是有限数值 o.length=0//且为非负值 o.length===Math.floor(o.length)//且是整数 o.length4294967296){//且小于2^32 return true;//则o是类数组对象 }else{ return false;//否则不是 }} 类数组对象:拥有一个数值length属性和对应非负整数属性的对象,比如arguments对象和一些DOM方法返回的对象 以上这篇js 用于检测类数组对象的函数方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持码农之家。 ……

网友NO.119907

JS实现给数组对象排序的方法分析

本文实例讲述了JS实现给数组对象排序的方法。分享给大家供大家参考,具体如下: JS中给数组对象排序 假设有一个对象数组,我们想要根据某个对象属性对数组进行排序。而传递给数组 sort() 方法的比较函数要接收2个参数,即要比较的值。 可是,我们需要一种方式指明按照哪个属性来排序。 要解决这个问题,可以定义一个函数,它接收一个属性名,然后根据这个属性名来创建一个比较函数。 function createComprisonFunction(propertyName){ return function(object1,object2){ var value1 = object1[propertyName]; var value2 = object2[propertyName]; if(value1 value2){ return -1; }else if(value1 value2){ return 1; }else{ return 0; } }}//上面的函数可以像在下面的列子中这样使用var data = [{name:"Zachary",age:28},{name:"Nicholas",age:29}];data.sort(createComprisonFunction("name"));console.log(data[0].name); //Nicholasdata.sort(createComprisonFunction(……

网友NO.909729

js array数组对象操作方法汇总

js 数组对象操作方法如下: 1. 创建数组 var array1 = [1,2] //方法一var array2 = new Array() //方法二array[0] = 1;array[1] = 2; 2.遍历数组 for循环 和for...in 循环 var array1 = [1,2];var l = array1.length;//for循环for(var i=0;i l;i++){ console.log(array1 [i]);}//for...in 循环for (x in array1 ){ console.log(array1 [x]);} 3. concat() 连接两个或以上的数组, 返回的是一个新数组,不影响原数组 (concat 合并多个数组(加的是数组中的元素),也可跟元素合并) var arr = [1];var arr1 = ["herry"]var arr3 = arr.concat(arr1); //[1,"herry"] 4.push() 方法可向数组的末尾添加一个或多个元素,该方法会 改变原数组 ,并且遵循数组提供的先进后出栈功能,返回值是 数组新的长度 (unshift() 方法是向数组头部添加一个或多个元素,使用上同push方法,但不推荐使用,因为无法再IE下正常使用) var arr = [1];var arr1 = "herry";var arr2 = ["herry"];//注意向……

网友NO.826288

Java获取json数组对象的实例讲解

如下所示: JSONArray jsonArray1 = jsonObject.getJSONArray("result"); for (int i = 0; i jsonArray1.length(); i++) { JSONObject temp = (JSONObject) jsonArray1.get(i); String x = temp.getString("x"); String y = temp.getString("y"); if (x == null || y == null) { flag = false; handler.sendEmptyMessage(NO_LOCATION); }} 以上这篇Java获取json数组对象的实例讲解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持码农之家。 ……

<
1
>

电子书 编程教程 文档 软件 源码 视频

Copyright 2018-2020 xz577.com 码农之家

本站所有电子书资源不再提供下载地址,只分享来路

免责声明:网站所有作品均由会员网上搜集共同更新,仅供读者预览及学习交流使用,下载后请24小时内删除

版权投诉 / 书籍推广 / 赞助:QQ:520161757