我试图推多个元素作为一个数组,但得到一个错误:
> a = []
[]
> a.push.apply(null, [1,2])
TypeError: Array.prototype.push called on null or undefined
我试图做类似的事情,我在ruby中做,我认为应用是类似*的东西。
>> a = []
=> []
>> a.push(*[1,2])
=> [1, 2]
我试图推多个元素作为一个数组,但得到一个错误:
> a = []
[]
> a.push.apply(null, [1,2])
TypeError: Array.prototype.push called on null or undefined
我试图做类似的事情,我在ruby中做,我认为应用是类似*的东西。
>> a = []
=> []
>> a.push(*[1,2])
=> [1, 2]
作为一种选择,你可以使用Array.concat:
var result = a.concat(b);
这将创建并返回一个新数组,而不是将项推入同一个数组。如果您不想修改源数组,而是要对其进行浅拷贝,那么它可能很有用。
当使用apply或call使用对象的大多数函数时,context参数必须是您正在处理的对象。
在这种情况下,你需要。推一把。apply(a,[1,2])(或者更准确地说是Array.prototype.push。应用(a [1, 2]))
现在在ECMAScript2015(也就是ES6)中,你可以使用展开操作符一次添加多个项:
var arr = [1]; var newItems = [2, 3]; arr.push(...新项目); 控制台.log(到达);
请参阅Kangax的ES6兼容性表,了解哪些浏览器是兼容的
如果你想要Array的替代品。concat在ECMAScript 2015(也就是ES6, ES2015),像它一样,不修改数组,但返回一个新的数组,你可以像这样使用展开操作符:
瓦尔·阿r = [1] 姓简的行动; 姓沃的衣服 世界上的人arr, ...newItems, ... newerItems]; console.log (newArr);
注意,这与push方法不同,因为push方法会改变/修改数组。
如果你想看看某些ES2015特性在你的浏览器中是否有效,请检查Kangax的兼容性表。
如果你不想等待浏览器的支持,并且想在生产环境中使用ES2015,你也可以使用Babel或类似的转译器。
一次推入多个对象通常取决于如何声明数组。
我就是这么做的
//declaration
productList= [] as any;
现在推送记录
this.productList.push(obj.lenght, obj2.lenght, items);
如果你想添加多个项目,你可以使用Array.push()和展开操作符:
a = [1,2]
b = [3,4,5,6]
a.push(...b)
结果将是
a === [1,2,3,4,5,6]
更简单的方法是
a = []
a.push(1,2,3)
另一种方法是
a = [...a, 4,5,6]
如果你想创建另一个数组
const b = a.concat(7,8,9)
我也有同样的疑问,但对我来说,有一个更简单的解决办法:
let array = []
array.push(1, 2, 4, "string", new Object())
console.log(array)
// logs [ 1, 2, 4, 'string', {} ]
假设你有一个包含前10个数字的数组,但缺少一个数字,比如6。 您可以使用以下代码将其插入到索引5处的数组中
函数insert(数组,索引,obj) { 返回[…array.slice(0,index), obj,…array.slice(index)] } 让arr = [1,2,3,4,5,7,8,9,0] Arr = insert(Arr, 5,6) console.log (arr)