想了解delete的机制缘起一个现象,我无法解释,也无法理解。

首先看一下下面这个例子:
var x = 1;
delete x; //false
然后我又执行了一次:
y = 2;
delete y; //true
看到上面的结果,我比较吃惊,为什么同样是删除,区别怎么这么大呢?进而我想学习和了解一下JS delete的机制。
 在MDN(Mozilla Developer Network)上看到下面一个例子
x = 42;         // creates the property x on the global object
var y = 43; // declares a new variable, y
myobj = {
h: 4,
k: 5
}; delete x; // returns true (x is a property of the global object and can be deleted)
delete y; // returns false (delete doesn't affect variable names)
delete Math.PI; // returns false (delete doesn't affect certain predefined properties)
delete myobj.h; // returns true (user-defined properties can be deleted) delete myobj; // returns true (myobj is a property of the global object, not a variable, so it can be deleted)
我们可以看出,delete元算符执行的结果要么是true,要么是false。那么什么时候返回true,什么时间返回false呢?
简单的总结了一句话:只要可以被删除,就会返回true(看起来像是一句废话,可能实际上也是一句废话)
 
此时我们要讨论的就是什么时候才能被删除?
 
总结上面的例子我们发现:
1.在global object上的属性可以被删除;
2.声明的变量不能被删除
3.未声明的全局变量可以被删除
4.内置对象的属性不能被删除
 
为什么会有这个结果?
要想知道原理,首先了解两个概念:上下文和属性特性。
 
1.上下文
我们知道每条语句在执行的时候,他都会处在一个环境中,这个环境就是这条语句的上下文环境。当一个函数执行时,会进入函数代码执行的上下文;全局代码执行时,会进入全局代码执行的上下文。每个执行上下文中都会存在一个内部的可变对象(variable object),当进入这个环境的时候,会实例化这个可变对象,然后声明的变量和方法,都会作为这个可变对象的属性。那么在上述所说到的两个执行环境就会实例化两种对象,全局对象(global object)和激活对象(activation object)。
2.属性特性
ECMAScript5中可以查询,设置这些特性。我们将存取器属性的getter,setter方法看成是属性的特性,同理,可以把数据属性的值看做属性的特性。所以可认为一个属性包含一个名字和4个特性(见下表)。 ECMACScript5定义了一个名为“属性描述符”的对象。这个对象代表那4个特性。通过Object.getOwnPropertyDescriptor(object, propertyname)可以获得某个对象特定属性的属性描述符。
特性名
说明
Configurable
设置属性是否可配置,即能否更改(包括名值)或者删除(delect)它,能否修改属性特性等等
Enumerable
设置属性是否可以枚举,即能否通过for-in循环返回
Writable
是否可写
Value
就是属性值,对象在读取属性值时就是从这个位置读取的.

这里delete会涉及到Configurable特性。可通过上述方法getOwnPropertyDescriptor简单判断是否可以delete。开始说的两个例子的结果如下:

var x = 1;
Object.getOwnPropertyDescriptor(window, 'x'); //configurable= false
delete x; //false
y = 2;
Object.getOwnPropertyDescriptor(window, 'y'); //configurable= true
delete y; //true
这里还需要交代的是,属性的特性是在创建的时候就确定的,赋值并不能改变它的特性,
function sum() {}
sum = 1;
Object.getOwnPropertyDescriptor(window, 'sum'); //configurable= false
delete sum; //false
但是可以通过这个方法定义的特性值Object.defineProperties(object, descriptors),
Object.defineProperties(window, {sum1:{value:1,configurable:true}});
Object.getOwnPropertyDescriptor(window, 'sum'); //configurable= true
delete sum1; //true
Object.defineProperties(window, {sum2:{value:1,configurable:false}});
Object.getOwnPropertyDescriptor(window, 'sum'); //configurable= false
delete sum2; //false
 
总结一下delete不能删除属性:
 
1.声明的变量(变量、函数、函数参数)不能删除;如:var x=1;
2.内置对象的属性不能删除;如:Math.PI
3.定义的变量属性的configurable值为false的,不能删除。
注意:IE6-8下delete window属性会报类型错误
 
 
参考文献:
http://blog.csdn.net/jiushuai/article/details/6020739
http://perfectionkills.com/understanding-delete/

javascript delete机制学习的更多相关文章

  1. 【移动端兼容问题研究】javascript事件机制详解(涉及移动兼容)

    前言 这篇博客有点长,如果你是高手请您读一读,能对其中的一些误点提出来,以免我误人子弟,并且帮助我提高 如果你是javascript菜鸟,建议您好好读一读,真的理解下来会有不一样的收获 在下才疏学浅, ...

  2. javascript继承机制的设计思想(ryf)

    我一直很难理解Javascript语言的继承机制. 它没有"子类"和"父类"的概念,也没有"类"(class)和"实例" ...

  3. Javascript事件机制兼容性解决方案

    本文的解决方案可以用于Javascript native对象和宿主对象(dom元素),通过以下的方式来绑定和触发事件: 或者 var input = document.getElementsByTag ...

  4. 从setTimeout谈JavaScript运行机制

    从setTimeout说起 众所周知,JavaScript是单线程的编程,什么是单线程,就是说同一时间JavaScript只能执行一段代码,如果这段代码要执行很长时间,那么之后的代码只能尽情地等待它执 ...

  5. 重温javascript事件机制

    以前用过一段时间的jquery感觉太方便,太强大了,各种动画效果,dom事件.创建节点.遍历.控件及UI库,应有尽有:开发文档也很多,网上讨论的问题更是甚多,种种迹象表明jquery是一个出色的jav ...

  6. javascript delete方法

    学习delete可以参考下面两个博客,写的都很好,本文大部分参考与以下两个博客 http://www.cnblogs.com/windows7/archive/2010/03/28/1698387.h ...

  7. 转:Javascript继承机制的设计思想

    我一直很难理解Javascript语言的继承机制. 它没有"子类"和"父类"的概念,也没有"类"(class)和"实例" ...

  8. JavaScript 执行机制

    一.宏任务与微任务 macro-task(宏任务):包括整体代码script,setTimeout,setInterval micro-task(微任务):Promise,process.nextTi ...

  9. 转载---JavaScript执行机制

    很好的一篇文章,原地址 JavaScript执行机制 这一次,彻底弄懂 JavaScript 执行机制 本文的目的就是要保证你彻底弄懂javascript的执行机制,如果读完本文还不懂,可以揍我. 不 ...

随机推荐

  1. poj 2836 Rectangular Covering(状态压缩dp)

    Description n points are given on the Cartesian plane. Now you have to use some rectangles whose sid ...

  2. .net网站开发(一):1.input表单元素

    其实,在半年前我对网站开发还是完全不感冒的,不是没认识,而是只认识到表面.我以为网站模型就那几样,新闻.论坛.博客啥的,仿个站出来有什么意思?但现在我是知道了,大多应用开发还是采用B/S架构的,包括服 ...

  3. JMeter数据库性能测试

    要测试一个服务器的性能,客户要求向数据库内 1000/s(每插入一千条数据)的处理能力 前提条件:一个数据库:test   数据库下面有一张表:user   表中有两个字段:username.pass ...

  4. java实验7-多线程编程

    1 利用Thread和Runnable创建线程 [实验目的] (1)理解用实现Runnable接口的方法实现多线程. (2)掌握线程优先级的设置. (3)加深对线程状态转换的理解. [实验要求] 要求 ...

  5. C# winform带进度条的图片下载

    代码如下: public partial class FrmMain : Form { public FrmMain() { InitializeComponent(); } private void ...

  6. centos6.5配置无线网络

    由于安装的是服务器版,所以开机无法连接网络,以下这些情况都是针对驱动已经安装OK.按步骤操作如下(以下操作默认都是在超级管理员权限下进行): 1.测试电脑是否安装wpa_supplicant,测试方法 ...

  7. Label 表达式绑定

    Text='<%#"总金额为: "+Convert.ToString(Convert.ToDecimal(TextBox1.Text)*Convert.ToInt32(Tex ...

  8. win7_64位主机装虚机Linux系统(VMware Workstation10+CentOS6.5)详细步骤图文讲解

    第一步:创建新的虚拟机 第二步:选择“典型”安装 第三步:选择映像文件安装—浏览选择iso文件 第四步:选择稍后安装操作系统 第五步:系统选择Linux,版本选择centOS64位 第六步:虚拟机名称 ...

  9. 定义了重复的system.web.extensions/scripting/scriptResourceHandler怎么办

    今天移转系统,都配置好之后,系统报错说我的web服务下的web.config 定义了重复的 system.web.extensions/scripting/scriptResourceHandler ...

  10. mysql索引之组合索引

    多列索引又称组合索引,在mysql的查询操作中,我们经常会遇到多个搜索条件,如:$sql = "select * from article where content='ma4' and t ...