我有:
var array = new Array();
array.push("A");
array.push("B");
array.push("C");
我希望能够做到:
array.remove (" B ");
但是没有移除函数。我该怎么做呢?
我有:
var array = new Array();
array.push("A");
array.push("B");
array.push("C");
我希望能够做到:
array.remove (" B ");
但是没有移除函数。我该怎么做呢?
当前回答
简单解决方案(ES6)
如果你没有重复元素
Array.prototype.remove = function(elem) {
var indexElement = this.findIndex(el => el === elem);
if (indexElement != -1)
this.splice(indexElement, 1);
return this;
};
在线演示(小提琴)
其他回答
简单的
array.splice(array.indexOf(item), 1);
use:
array.splice(2, 1);
这将从数组中删除一项,从索引2开始(第3项)
以相反的顺序遍历列表,并使用.splice方法。
var array = ['A', 'B', 'C']; // Test
var search_term = 'B';
for (var i=array.length-1; i>=0; i--) {
if (array[i] === search_term) {
array.splice(i, 1);
// break; //<-- Uncomment if only the first term has to be removed
}
}
当必须删除所有出现的搜索词时,反向顺序很重要。否则,计数器将增加,您将跳过元素。
当只有第一个事件必须删除时,以下也将起作用:
var index = array.indexOf(search_term); // <-- Not supported in <IE9
if (index !== -1) {
array.splice(index, 1);
}
一行列表
让我们来解决这个数组的问题:
var array = ['A', 'B', 'C'];
1. 只删除第一个: 使用“如果您确定项目存在”
array.splice(array.indexOf('B'), 1);
2. 只删除最后一个: 使用“如果您确定项目存在”
array.splice(array.lastIndexOf('B'), 1);
3.删除所有出现的情况:
array = array.filter(v => v !== 'B');
const changedArray = array.filter( function(value) {
return value !== 'B'
});
或者你可以用:
const changedArray = array.filter( (value) => value === 'B');
changedArray将包含没有值的'B'