×

js里把对象转换成数组

作者:andy0012020.03.11来源:Web前端之家浏览:32113评论:0
关键词:js对象数组

JavaScript可以使用数组的slice方法将对象转换为数组,需要将对象添加一个length属性,然后使用call或者apply来实现函数调用时的所属对象,就可以使用slice方法实现转换。

javascript将对象转换成数组:

下面是一个简单的数组:

var arr = [2,44,12,5,8]
arr.slice()
>>(5) [2,44,12,5,8]

但是普通的对象是没有slice方法的,可以用call或者apply来实现函数调用时的所属对象。

var obj = {0:'q',1:'w',2:'e'}
Array.prototype.slice.call(obj)
>>[]

但是结果却是为空数组,这是因为slice函数是可以处理数组或类数组对象,所以这里需要把obj对象添加一个length属性变成类数组:

obj.length = 3
Array.prototype.slice.call(obj)
>>(3) ['q','w','e']

这里如果把length的大小改成大于或小于属性数量:

obj.length = 2
Array.prototype.slice.call(obj)
>>(2) ['q','w']

obj.length = 4
Array.prototype.slice.call(obj)
>>(4) ['q','w','e',empty]

当属性名不是整形或者不是从0开始:

obj = {'q':1,'w':2,'e':3}
obj.length = 3
Array.prototype.slice.call(obj)
>>(3) [empty*3]

obj = {2:'q',3:'w',4:'e'}
obj.length = 3
Array.prototype.slice.call(obj)
>>(3) [empty*2,'q']

您的支持是我们创作的动力!
温馨提示:本文作者系 ,经Web前端之家编辑修改或补充,转载请注明出处和本文链接:
https://www.jiangweishan.com/article/jsjhfg09823409823048320.html

网友评论文明上网理性发言 已有0人参与

发表评论: