诡异的delete

delete这个操作符呢,在javascript中不是很常用,但是他的特性的确很诡异。

1,删除对象的属性,代码:

  1. var o = {
  2.     a: 1,
  3.     b: 2   
  4. };
  5. delete o.a;
  6. alert(o.a)//undefined

那么到底delete删除的是对象的属性还是对象的属性值呢,我开始觉得删除的应该是值,因为结果是undefined,而没有报错。但是事实上,我的看法是错误的,举例说明:

  1. var o = {};
  2. var a = { 
  3.     pro: "zhenn" 
  4. };
  5. o.c = a;
  6. delete o.c;    //删除对象o的属性a
  7. console.log(o.c);     // undefined
  8. console.log(a.pro);   // zhenn

通过上述代码,不难看出在delete o.c之后呢,并没有删除o.c所指向的值,也就是对象a依然存在,否则a.pro应该是过不了编译这关的。说到这里,可以这么理解delete删除对象的属性,其实相当于删除了对对象中属性值的引用而已,但是这个值依然在对象栈中!

2,对数组的操作,先看代码:

  1. var arr = [1,2,3];
  2. delete arr[2];
  3. console.log(arr.length)// 3
  4. console.log(arr);   // [1,2,undefined]

又一次证明了,delete并没有真正删除元素,只是删除了元素所对应的键值。为了更进一步认清delete的本质,和Array中的pop方法比较一下。如下:

  1. var arr = [1,2,3];
  2. arr.pop();
  3. console.log(arr)// [1,2]
  4. console.log(arr.length)  // 2

这下应该真相大白了。

3,以上对对象和数组的操作,还很好理解,但是对于变量的操作,难免让人琢磨不透,代码如下:

  1. var a = 1;
  2. delete a;
  3. alert(a); // 1
  4.  
  5. function fn(){ return 42; }
  6. delete fn;
  7. alert(fn())// 42
  8.  
  9. b = 2;
  10. delete b;
  11. alert(b)// b is not defined;

很难解释通啊,同样是全局变量,用var声明的竟然删除不了,而直接声明的变量b竟然可以删除,不能不说delete很诡异了,在ECMA给出的解释中,也仅仅是说通过var声明的变量和通过function声明的函数拥有DontDelete特性,无法被删除。

标签:

2 条评论 发表在“诡异的delete”上

  1. simaopig 说:

    最后的变量的确实很诡异,不理解。呵呵。

    不过感觉前面说的对象的有点不正确,其实那个存的就是值,只不过值的内容就是一个引用地址的指针。

    而我感觉数组所占用的空间其实是固定的吧?由其length决定。而delete其元素后,长度不变。该元素值变为了undefined.

    上面只是胡乱猜的,没有任何验证。呵呵。

    [回复]

  2. 柳亚 说:

    呵呵,看不懂,但还是留个脚印。。。。

    [回复]

留下回复