我有一个数组MyArray,想要删除在位置i上的一个元素。
我尝试了:
我尝试了:
MyArray = MyArray.splice(i, 1);
但它返回的是我想要移除的元素,而不是不含该元素的数组。
我相信这是一个简单的修复,不管怎样还是谢谢。
MyArray = MyArray.splice(i, 1);
但它返回的是我想要移除的元素,而不是不含该元素的数组。
我相信这是一个简单的修复,不管怎样还是谢谢。
修改
MyArray = MyArray.splice(i, 1);
转换为
MyArray.splice(i, 1);
splice()是一种具有副作用的破坏性方法。虽然它返回已删除的元素,但它会修改你传入的实际数组。
alert("Before: " + MyArray);
MyArray.splice(i, 1);
alert("After: " + MyArray);
splice
方法直接修改原数组。
var arr = [1, 2, 3, 4];
// arr is [1, 2, 3, 4];
var el = arr.splice(0, 1);
// el is [1], arr is now [2, 3, 4].
你已经基本掌握了!但是不要将其分配给新值..只需使用现有的数组。
MyArray.splice(i, 1);
Something = MyArray;
array.splice(index , howMany[, element1[, ...[, elementN]]])
更改数组的内容,添加新元素并删除旧元素。
包含已删除元素的数组。如果只删除一个元素,则返回一个元素的数组。如果没有删除任何元素,则返回一个空数组。
我曾经有过类似的问题,特别是因为我只想删除数组中的特定项,而不是所有匹配该项的所有项。
我为KO可观察数组创建了这个扩展程序,它似乎起作用。 我还没有尝试过对象数组,但我不认为那会有问题。
当我第一次学习KO时,处理数组非常困难,所以我希望这对其他人有用:
JavaScript:
ko.observableArray.fn.removeAt = function (index) {
this.valueWillMutate();
this.splice(index, 1);
this.valueHasMutated();
}
HTML:
<div data-bind="foreach: Answers">
<input type="text" data-bind="value: $data"/>
<button
data-bind="click: function(){ $parent.Answers.removeAt($index()) }"
title="Remove"
>X</button>
</div>
这是另一种方式(如果您仍然想将其设置为变量并保持原始数组不变):
// example array
var foo = ['1', '13', '44', '17', '17', '19', '1', '7', '17'];
// lets say we want to remove one of the 17s from the array
// convert array to string, do replacements, then convert back
var bar = foo.join().replace('17', '').replace(/\,\,/gi, ',').split(',');
// should log ['1', '13', '44', '17', '19', '1', '7', '17']
console.log(bar);
根据数组的结构,有时查询/操作字符串比数组更容易(有时反之亦然)