假设我有这样的代码:
var myArray = new Object();
myArray["firstname"] = "Bob";
myArray["lastname"] = "Smith";
myArray["age"] = 25;
现在如果我想删除“lastname”?....有什么等价物吗 (“姓”)myArray .remove () ?
(我需要元素消失,因为元素的数量很重要,我想保持东西干净。)
假设我有这样的代码:
var myArray = new Object();
myArray["firstname"] = "Bob";
myArray["lastname"] = "Smith";
myArray["age"] = 25;
现在如果我想删除“lastname”?....有什么等价物吗 (“姓”)myArray .remove () ?
(我需要元素消失,因为元素的数量很重要,我想保持东西干净。)
当前回答
这只是删除对象,但它仍然保持数组长度不变。
要从数组中移除元素,你需要做如下操作:
array.splice(index, 1);
其他回答
JavaScript中的对象可以看作是关联数组,将键(属性)映射到值。
要在JavaScript中从对象中删除一个属性,可以使用delete操作符:
const o = { lastName: 'foo' }
o.hasOwnProperty('lastName') // true
delete o['lastName']
o.hasOwnProperty('lastName') // false
请注意,当delete应用于数组的索引属性时,您将创建一个稀疏填充的数组(例如。缺少索引的数组)。
当使用Array的实例时,如果您不想创建稀疏填充的数组(通常也不想),那么您应该使用array# splice或array# pop。
请注意,JavaScript中的delete操作符并不直接释放内存。它的目的是从对象中删除属性。当然,如果被删除的属性持有对对象o的唯一剩余引用,那么o随后将以正常方式被垃圾收集。
使用delete操作符会影响JavaScript引擎优化代码的能力。
在Airbnb风格指南(ECMAScript 7)中有一种优雅的方式来做到这一点:
const myObject = {
a: 1,
b: 2,
c: 3
};
const { a, ...noA } = myObject;
console.log(noA); // => { b: 2, c: 3 }
版权:https://codeburst.io/use-es2015-object-rest-operator-to-omit-properties-38a3ecffe90
“数组”:
如果你知道索引:
array.splice(index, 1);
如果你知道这个值:
function removeItem(array, value) {
var index = array.indexOf(value);
if (index > -1) {
array.splice(index, 1);
}
return array;
}
得到最多好评的delete答案适用于对象,但不适用于实际数组。如果我使用删除,它从循环中删除元素,但保持元素为空,数组的长度不会改变。在某些情况下,这可能是一个问题。
例如,如果我在删除myArray后对myArray执行myArray. tostring(),它会创建一个空条目,即,。
我唯一的工作方法是:
function removeItem (array, value) {
var i = 0;
while (i < array.length) {
if(array[i] === value) {
array.splice(i, 1);
} else {
++i;
}
}
return array;
}
用法:
var new = removeItem( ["apple","banana", "orange"], "apple");
// ---> ["banana", "orange"]
如果,出于某种原因,删除键不起作用(就像它对我不起作用一样),你可以将它拼接出来,然后过滤未定义的值:
// To cut out one element via arr.splice(indexToRemove, numberToRemove);
array.splice(key, 1)
array.filter(function(n){return n});
不要尝试连接它们,因为拼接返回删除的元素;