JS数组追加数组采用push.apply的坑(转)
2016-11-30 10:53
399 查看
JS数组追加数组没有现成的函数,这么多年我已经习惯了a.push.apply(a, b);这种自以为很酷的,不需要写for循环的写法,一直也没遇到什么问题,直到今天我要append的b是个很大的数组时才遇到了坑。
以上的代码在mac的chrome下抛出了如下的异常
如果把数组改为b = new Array(125623);小一个元素居然就好了,测试了一下其他浏览器也都有大数组才出错的问题,但不同浏览器临界值还各异。
搜索了http://stackoverflow.com/questions/1374126/how-to-append-an-array-to-an-existing-javascript-array/17368101#17368101 发现也有人遇到这样的坑:
给出的建议是老老实实用forEach,不仅可以避免大数组的异常问题,并且从性能角度考虑forEach也是最快的
这个小坑给了我两点思考:
1、有些花哨的用法如a.push.apply(a, b);还是用于面试题装逼就行,实战上还是多走老实路线免得遇到异常和性能的坑,例如小数量的如这篇的这个几十个节点的3D网络拓扑弹簧布局例子玩玩倒是没问题,遇到真正大数据量如这篇中的HT for Web的这个3D大数据量性能例子才能考验出问题。
2、http://stackoverflow.com/questions/1374126 从stackoverflow找答案时不要仅盯着投票最多的,真理往往掌握在少数人手中,下图259票的回答是个坑,34票的才是最完美的分析:
搜索了http://stackoverflow.com/questions/1374126/how-to-append-an-array-to-an-existing-javascript-array/17368101#17368101 发现也有人遇到这样的坑:
这个小坑给了我两点思考:
1、有些花哨的用法如a.push.apply(a, b);还是用于面试题装逼就行,实战上还是多走老实路线免得遇到异常和性能的坑,例如小数量的如这篇的这个几十个节点的3D网络拓扑弹簧布局例子玩玩倒是没问题,遇到真正大数据量如这篇中的HT for Web的这个3D大数据量性能例子才能考验出问题。
2、http://stackoverflow.com/questions/1374126 从stackoverflow找答案时不要仅盯着投票最多的,真理往往掌握在少数人手中,下图259票的回答是个坑,34票的才是最完美的分析:
相关文章推荐
- 关于JS数组追加数组采用push.apply的问题
- JS数组追加数组采用push.apply的坑
- JS数组追加数组采用push.apply的坑
- 关于JS数组追加数组采用push.apply的问题
- JS数组追加数组採用push.apply的坑
- js数组合并concat()和Array.prototype.push.apply()的性能分析
- js数组合并concat()和Array.prototype.push.apply()的性能分析
- js数组合并concat()和Array.prototype.push.apply()的性能分析
- js使用数组作为参数,直接调用push与apply方法调用push的区别
- Js数组中的pop ,push,unshift,splice,shift方法
- js 数组 pop,push,unshift,splice,shift
- js 数组操作之pop,push,unshift,splice,shift
- Js~数组的操作push,pop,shift,unshift
- IE8对JS的数组,采用属性遍历的方法,解析不一样的地方:
- 关于js全局变量数组push数据时dom中无数据的问题
- JS 数组array方法push, pop, unshift, shift, slice,splice,contact, join, sort
- Js数组的方法pop,push,unshift,splice,shift
- JS中数组添加元素----Array.push()
- Js数组pop,push,unshift,splice,shift方法
- Js:数组的各种方法范例pop,push,unshift,splice,shift