我有一个在 TypeScript 中创建的数组,它有一个我用作键的属性。如果我有那个钥匙,我怎样才能从中删除一个项目?
与在 JavaScript 中的方式相同。
delete myArray[key];
请注意,这会将元素设置为 undefined
。
最好使用 Array.prototype.splice
函数:
const index = myArray.indexOf(key, 0);
if (index > -1) {
myArray.splice(index, 1);
}
let foo_object; // Itemitem(object here) to remove
this.foo_objects = this.foo_objects.filter(obj => return obj !== foo_object);
this.foo_objects = this.foo_objects.filter(obj => obj !== foo_object)[0];
使用 ES6,您可以使用以下代码:
removeDocument(doc){
this.documents.forEach( (item, index) => {
if(item === doc) this.documents.splice(index,1);
});
}
这是我的解决方案:
onDelete(id: number) {
this.service.delete(id).then(() => {
let index = this.documents.findIndex(d => d.id === id); //find index in your array
this.documents.splice(index, 1);//remove element from array
});
event.stopPropagation();
}
您可以对数组使用 splice
方法来移除元素。
例如,如果您有一个名为 arr
的数组,请使用以下内容:
arr.splice(2, 1);
所以这里索引为 2 的元素将是起点,参数 2 将确定要删除多少个元素。
如果要删除名为 arr
的数组的最后一个元素,请执行以下操作:
arr.splice(arr.length-1, 1);
这将返回 arr 并删除最后一个元素。
例子:
var arr = ["orange", "mango", "banana", "sugar", "tea"];
arr.splice(arr.length-1, 1)
console.log(arr); // return ["orange", "mango", "banana", "sugar"]
pop
方法而不是 splice
。
让部门是一个数组。你想从这个数组中删除一个项目。
departments: string[] = [];
removeDepartment(name: string): void {
this.departments = this.departments.filter(item => item != name);
}
这对我有用。
你的数组:
DummyArray: any = [
{ "id": 1, "name": 'A' },
{ "id": 2, "name": 'B' },
{ "id": 3, "name": 'C' },
{ "id": 4, "name": 'D' }
]
功能:
remove() {
this.DummyArray = this.DummyArray.filter(item => item !== item);
}
注意:此函数会删除数组中的所有对象。如果要从数组中删除特定对象,请使用此方法:
remove(id) {
this.DummyArray = this.DummyArray.filter(item => item.id !== id);
}
这是一个简单的衬线,用于从对象数组中按属性删除对象。
delete this.items[this.items.findIndex(item => item.item_id == item_id)];
或者
this.items = this.items.filter(item => item.item_id !== item.item_id);
如果您需要从数组中删除给定对象并且您希望确保以下内容,请使用此选项:
列表未重新初始化
数组长度已正确更新
const objWithIdToRemove;
const objIndex = this.objectsArray.findIndex(obj => obj.id === objWithIdToRemove);
if (objIndex > -1) {
this.objectsArray.splice(objIndex, 1);
}
const
而不是 let
。
Typescript/Javascript 中的多个选项可从 Array 中删除元素。拼接是最好的选择
它在不创建新对象的情况下删除内联它正确更新数组的长度(不会留下空白的空元素)
下面是使用 Splice 函数根据对象数组中的某些字段删除对象的示例
常量人员 = [ { firstName :'John', lastName :'Michel' }, { firstName :'William', lastName :'Scott' }, { firstName :'Amanda', lastName :'Tailor' } ] console.log( '删除前:'+JSON.stringify(persons)); console.log('删除威廉:'); person.splice(persons.findIndex(item => item.firstName === 'William'),1); console.log('删除威廉之后'+JSON.stringify(persons));
使用 TypeScript 扩展运算符回答 (...)
// Your key
const key = 'two';
// Your array
const arr = [
'one',
'two',
'three'
];
// Get either the index or -1
const index = arr.indexOf(key); // returns 0
// Despite a real index, or -1, use spread operator and Array.prototype.slice()
const newArray = (index > -1) ? [
...arr.slice(0, index),
...arr.slice(index + 1)
] : arr;
使用 Typescript 的另一种解决方案:
let updatedArray = [];
for (let el of this.oldArray) {
if (el !== elementToRemove) {
updated.push(el);
}
}
this.oldArray = updated;
let a: number[] = [];
a.push(1);
a.push(2);
a.push(3);
let index: number = a.findIndex(a => a === 1);
if (index != -1) {
a.splice(index, 1);
}
console.log(a);
只是想为数组添加扩展方法。
interface Array<T> {
remove(element: T): Array<T>;
}
Array.prototype.remove = function (element) {
const index = this.indexOf(element, 0);
if (index > -1) {
return this.splice(index, 1);
}
return this;
};
您可以尝试先获取列表或数组的索引或位置,然后使用 for 循环将当前数组分配给临时列表,过滤掉不需要的项目并将想要的项目存储回原始数组
removeItem(index) {
var tempList = this.uploadFile;
this.uploadFile = [];
for (var j = 0; j < tempList.length; j++) {
if (j != index)
this.uploadFile.push(tempList[j]);
}
}
我们可以使用 filter
和 includes
实现逻辑
const checkAlpha2Code = ['BD', 'NZ', 'IN'] 让 countryAlpha2Code = ['US', 'CA', 'BD', 'NZ', 'AF' , 'AR' , 'BR'] /* * * 在删除与 checkAlpha2Code 匹配的元素后返回修改后的数组 countryAlpha2Code */ countryAlpha2Code = countryAlpha2Code.filter(alpha2code => { return !checkAlpha2Code.includes(alpha2code); }); console.log(countryAlpha2Code) // 输出: [ 'US', 'CA', 'AF', 'AR', 'BR' ] // 再次重置值 countryAlpha2Code = ['US', 'CA', 'BD ', 'NZ', 'AF' , 'AR' , 'BR'] /** * 返回修改后的数组 countryAlpha2Code * 仅匹配带有 checkAlpha2Code 的元素 */ countryAlpha2Code = countryAlpha2Code.filter(alpha2code => { return checkAlpha2Code.包括(alpha2code);}); console.log(countryAlpha2Code) // 输出:[ 'BD', 'NZ' ]
我看到很多抱怨 remove
方法不是内置的。考虑使用 Set
而不是数组 - 它内置了 add
和 delete
方法。
类似于 Abdus Salam Azad answer ,但将数组作为参数从 //https://love2dev.com/blog/javascript-remove-from-array/ 传递
function arrayRemove(arr:[], value:any) {
return arr.filter(function(ele){
return ele != value;
});
}
var index: number = myArray.indexOf(key, 0);
indexOf
返回一个number
?index
,并且其中一个地方 (splice
) 想要看到一个数字,否则您会收到错误消息。目前,编译器无法阻止您在那里犯错。var index = myArray.findIndex(x => x.prop==key.prop);
。delete myArr[2]
从字面上删除了myArr
的 属性2
,这也与myArr[2] = undefined
不同。这个故事的寓意是只使用splice
来完成这项任务,因为它是一种安全的方式来获得所需的效果,而不会混淆副作用。