expression 的计算结果应该是某个属性的引用,例如:
delete object.property delete object['property']object
对象的名称,或计算结果为对象的表达式。
property
要删除的属性。
对于所有情况都是true,除非属性是一个自己不可配置的属性,在这种情况下,非严格模式返回 false。
在严格模式下,如果是属性是一个自己不可配置的属性,会抛出Global_objects/SyntaxError。
与通常的看法不同,delete操作符与直接释放内存无关。内存管理 通过断开引用来间接完成的,查看内存管理页可了解详情。
delete 操作符会从某个对象上移除指定属性。成功删除的时候回返回 true,否则返回 false。但是,以下情况需要重点考虑:
如果你试图删除的属性不存在,那么delete将不会起任何作用,但仍会返回true如果对象的原型链上有一个与待删除属性同名的属性,那么删除属性之后,对象会使用原型链上的那个属性(也就是说,delete操作只会在自身的属性上起作用)任何使用 var 声明的属性不能从全局作用域或函数的作用域中删除。 这样的话,delete操作不能删除任何在全局作用域中的函数(无论这个函数是来自于函数声明或函数表达式)除了在全局作用域中的函数不能被删除,在对象(object)中的函数是能够用delete操作删除的。任何用let或const声明的属性不能够从它被声明的作用域中删除。不可设置的(Non-configurable)属性不能被移除。这意味着像Math, Array, Object内置对象的属性以及使用Object.defineProperty()方法设置为不可设置的属性不能被删除。下面的代码块给出了一个简单的例子:
var Employee = { age: 28, name: 'abc', designation: 'developer' } console.log(delete Employee.name); // returns true console.log(delete Employee.age); // returns true // 当试着删除一个不存在的属性时 // 同样会返回true console.log(delete Employee.salary); // returns true当一个属性被设置为不可设置,delete操作将不会有任何效果,并且会返回false。在严格模式下会抛出语法错误(SyntaxError)。
var Employee = {}; Object.defineProperty(Employee, 'name', {configurable: false}); console.log(delete Employee.name); // returns falsevar, let以及const创建的不可设置的属性不能被delete操作删除。
var nameOther = 'XYZ'; // 通过以下方法获取全局属性: Object.getOwnPropertyDescriptor(window, 'nameOther'); // 输出: Object {value: "XYZ", // writable: true, // enumerable: true, // configurable: false} // 因为“nameOther”使用var关键词添加, // 它被设置为不可设置(non-configurable) delete nameOther; // return false在严格模式下,这样的操作会抛出异常。
在严格模式下,如果对一个变量的直接引用、函数的参数或者函数名使用delete操作,将会抛出语法错误(SyntaxError)。
任何使用var声明的变量都会被标记为不可设置的。在下面的例子中,salary是不可设置的以及不能被删除的。在非严格模式下,下面的delete操作将会返回false。
function Employee() { delete salary; var salary; } Employee();让我们来看看相同的代码在严格模式下会有怎样的表现。会抛出一个语法错误( SyntaxError)而不是返回false。
"use strict"; function Employee() { delete salary; // SyntaxError var salary; } // 相似的,任何对任何函数 // 直接使用delete操作将会抛出语法错误。 function DemoFunction() { //some code } delete DemoFunction; // SyntaxError在下面的示例中,我们删除一个对象的自己的属性,而原型链上具有相同名称的属性可用:
function Foo() { this.bar = 10; } Foo.prototype.bar = 42; var foo = new Foo(); // 返回 true,因为删除的是 foo 对象的自身属性 delete foo.bar; // foo.bar 仍然可用,因为它在原型链上可用。 console.log(foo.bar); // 从原型上删除属性 delete Foo.prototype.bar; // 输出 "undefined",因为不能继承这个属性了 console.log(foo.bar);当你删除一个数组元素时,数组的长度不受影响。即便你删除了数组的最后一个元素也是如此。
当用 delete 操作符删除一个数组元素时,被删除的元素已经不再属于该数组。下面的例子中用 delete 删除了 trees[3]。
var trees = ["redwood","bay","cedar","oak","maple"]; delete trees[3]; if (3 in trees) { // 这里不会执行 }如果你想让一个数组元素继续存在但是其值是 undefined,那么可以使用将 undefined 赋值给这个元素而不是使用 delete。下面的例子中,trees[3] 被赋值为 undefined,但该元素仍然存在。
var trees = ["redwood","bay","cedar","oak","maple"]; trees[3] = undefined; if (3 in trees) { // 这里会被执行 }如果你想通过改变数组的内容来移除一个数组元素,请使用splice方法。在下面的例子中,通过使用splice,将trees[3]从数组中移除。
var trees = ['redwood', 'bay', 'cedar', 'oak', 'maple']; trees.splice(3,1); console.log(trees); // ["redwood", "bay", "cedar", "maple"]