×

js里把对象转换成数组

作者:andy0012020.03.11来源:Web前端之家浏览:19805评论: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人参与

发表评论:

最新留言

  • Web前端之家

    已经加上了。...

  • 访客

    wordpress主题https://www.22vd.com,交换下友链麻烦通过...

  • Web前端之家

    你是可以试试的,其实用途有区别的。...

  • qdxx

    跟国内的比较Hchart等,如何?...

  • qdxx

    不错啊,收藏了!...

  • Web前端之家

    是的,多学习吧!...

  • qdxx

    这个的确坑,我也是刚遇到,感谢分享。...

  • 访客

    大苏打...

首页|JavaScript|HTML|HTML4|HTML5|CSS3|开发工具|性能优化|移动开发|前端教程|性能优化|开发工具|酷站欣赏|UI设计|前端教程

Copyright © 2021 Web前端之家(www.jiangweishan.com) 版权所有 All Rights Reserved.
粤ICP备12067512号-1

Copyright Your WebSite.Some Rights Reserved.

Powered By Z-BlogPHP 1.7.1