一、变量
说到javascript中的delete操作符,还是首先要搞清楚javascript中的变量和属性之间的关系。
javascript中,变量和对象属性关系非常微妙,甚至可以很多时候会被等同起来,因为 javascript 在执行脚本之前会创建一个global对象,在浏览器中就是window对象,所有的全局变量都是这个global对象的属性,执行函数时也会创建一个activation对象,所有的局部变量都是这个activation对象的属性。这些可以大家可以去了解一下javascript作用域和闭包。
//原型中声明的属性无法被删除 var global = 1; this.global; // 1, 可以通过this来访问global对象 this.global2 = 2; global2; // 12 function foo() { var local = 36; // 不过无法直接访问activation, // 因此无法通过 foo.local 的方式来访问local变量 }
似乎变量就等同于对象属性,其实不然,至少对于delete操作符来说还是不一样的。我的理解是变量声明是必须通过 var 语句来完成的,未通过var 语句声明的全局变量都是都是window对象的属性。这样就很容易的理解变量和对象属性的关系了。
二、delete操作符
delete操作符是用来删除对象属性的。对于引用类型的值,它也是删除对象属性的本身,不会删除属性指向的对象。如果有疑问可以看看基本类型和引用类型的值,或者测试下面的代码:
var o = {}; var a = { x: 10 }; o.a = a; delete o.a; // o.a属性被删除 console.log(o.a); // undefined console.log(a.x); // 10, 因为{ x: 10 } 对象依然被 a 引用,所以不会被回收
另外,delete o.x 也可以写作 delete o["x"],两者效果相同。
三、变量是不能删除的
通过var声明的变量和通过function声明的函数拥有dontdelete特性,是不能被删除。未通过var声明的全局变量(全局对象的属性)
var global = { a: 123, b: { c: 1345 } }; delete global; //无效 console.log(global) obj = { a: 123 }; delete obj; // 删除obj全局变量,window对象的obj属性 console.log(obj);//obj is not defined
四、原型中声明的属性和对象自带的属性无法被删除
原型prototype中声明的属性和对象自带的属性(其实这些属性也是在原型prototype中的)可以认为是带有dontdelete的特性的,无法被删除。例如
//原型中声明的属性无法被删除 function obj() { this.x = 1; } obj.prototype.x = 2; var o = new obj(); console.log(o.x); // 1, 构造函数中定义的o.x delete o.x; console.log(o.x); // 2, prototype中定义的o.x,即使再次执行delete o.x也不会被删除 //对象自带的属性无法被删除 var strings = "123456"; console.log(strings.length);//6 delete strings.length; console.log(strings.length);//依然是6
五、eval语句下的几个例外
eval执行的代码中,通过var声明的变量虽然与正常的var声明变量同属于global对象,但它们不具有dontdelete特性,能被删除。但是eval的代码中的函数内通过var定义的变量具有dontdelete,不能被删除。
eval("var x = 42;"); x; // => 42 delete x; x; // => referenceerror: x is not defined eval("function f() { return 12; }"); f(); // => 12 delete f; f(); // => referenceerror: f is not defined //eval执行的代码中,通过var声明的变量虽然与正常的var声明变量同属于global对象, // 但它们不具有dontdelete特性,能被删除。 eval("(function () {" + " var x = 42;" + " delete x;" + " return x;" + "})();") // => 42 // eval的代码中的函数内通过var定义的变量具有dontdelete,不能被删除。
六、delete的返回值
delete是普通运算符,会返回true或false。当被delete的对象的属性存在并且拥有dontdelete时 返回false,否则返回true。 这里的一个特点就是,对象属性不存在时也返回true,所以返回值并非完全等同于删除成功与否。
function c() { this.x = 42; } c.prototype.y = 12; var o = new c(); delete o.x; // true o.x; // undefined "x" in o; // false // o.x存在并且没有dontdelete,返回true delete o.y; // true o.y; // 12 // o自身没有o.y属性,所以返回true // 从这里也可以看到prototype链的存在,对象自身属性和prototype属性是不同的 delete o; // false // global.o拥有dontdelete特性所以返回false delete undefinedproperty; // true // global没有名为undefinedproperty的属性因此返回true delete 42; // true // 42不是属性所以返回true。有的实现会抛出异常(违反ecmascript标准) var x = 24; delete x++; // true x; // 25 // 被删除的是x++的返回值(24),不是属性,所以返回true
本文向大家介绍JavaScript中诡异的delete操作符,包括了JavaScript中诡异的delete操作符的使用技巧和注意事项,需要的朋友参考一下 delete这个操作符呢,在javascript中不是很常用,但是他的特性的确很诡异。 1,删除对象的属性,代码: 那么到底delete删除的是对象的属性还是对象的属性值呢,我开始觉得删除的应该是值,因为结果是undefined,而没有报错。但
本文向大家介绍Javascript中作用域的详细介绍,包括了Javascript中作用域的详细介绍的使用技巧和注意事项,需要的朋友参考一下 1、编译原理 在传统编译语言的流程中,程序中的一段代码执行前会经历三个步骤。统称为“编译”。 词法分析 将代码字符串分解成有意义的代码块,这些代码块称为词法单元。例如:在js中,var a = 2;。这段程序通常被拆分为以下词法单元。var、a、2、;。至
delete 操作符用于删除对象的某个属性;如果没有指向这个属性的引用,那它最终会被释放。(MDN) delete 操作符可以删除对象的一个属性。 JavaScript 中的关键字与其他语言略有不同,如 C++ 中的 delete 关键字会释放内存,JavaScript中不会,只有当一个值的引用归零时,才会被释放。 1. 使用 delete delete 操作符在与操作数运算结束后,会返回一个布尔
本文向大家介绍python操作xml文件详细介绍,包括了python操作xml文件详细介绍的使用技巧和注意事项,需要的朋友参考一下 关于python读取xml文章很多,但大多文章都是贴一个xml文件,然后再贴个处理文件的代码。这样并不利于初学者的学习,希望这篇文章可以更通俗易懂的教如何使用python 来读取xml 文件。 一、什么是xml? xml即可扩展标记语言,它可以用来标记数据、定义数据类
本文向大家介绍js中的内部属性与delete操作符介绍,包括了js中的内部属性与delete操作符介绍的使用技巧和注意事项,需要的朋友参考一下 在讲解Configurable之前,我们首先来看一道面试题: 从上面的这道题可以看出两个的区别:在没有使用var声明变量时,使用delete关键词是可以进行删除的,再次获取时值就是undefined了;在使用var声明的变量,使用delete是不能删除的,
本文向大家介绍JavaScript中的console.log()函数详细介绍,包括了JavaScript中的console.log()函数详细介绍的使用技巧和注意事项,需要的朋友参考一下 对于JavaScript程序的调试,相比于alert(),使用console.log()是一种更好的方式,原因在于:alert()函数会阻断JavaScript程序的执行,从而造成副作用;而console.log