假设我有这样的代码:

var myArray = new Object();
myArray["firstname"] = "Bob";
myArray["lastname"] = "Smith";
myArray["age"] = 25;

现在如果我想删除“lastname”?....有什么等价物吗 (“姓”)myArray .remove () ?

(我需要元素消失,因为元素的数量很重要,我想保持东西干净。)


当前回答

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引擎优化代码的能力。

其他回答

如果,出于某种原因,删除键不起作用(就像它对我不起作用一样),你可以将它拼接出来,然后过滤未定义的值:

// To cut out one element via arr.splice(indexToRemove, numberToRemove);
array.splice(key, 1)
array.filter(function(n){return n});

不要尝试连接它们,因为拼接返回删除的元素;

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引擎优化代码的能力。

如果你想要一个更实用和优雅的方法,你可以这样做:

const o = { firstName: "foo", lastName: "bar" };
const { lastName, ...removed } = o;
lastName // bar
removed // { firstName: "foo" }

注意,如果对象中没有剩余项,则remove的值将是未定义的。

JavaScript中的所有对象都实现为哈希表/关联数组。因此,以下是等价的:

alert(myObj["SomeProperty"]);
alert(myObj.SomeProperty);

并且,如前所述,你可以通过delete关键字从对象中“删除”一个属性,你可以通过两种方式使用它:

delete myObj["SomeProperty"];
delete myObj.SomeProperty;

希望额外的信息能有所帮助…

这只是删除对象,但它仍然保持数组长度不变。

要从数组中移除元素,你需要做如下操作:

array.splice(index, 1);