JavaScript中诡异的delete操作符

作者:junjie 时间:2024-04-10 16:15:33 

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

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


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

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


var o = {};
var a = {
    pro: "zhenn"
};
o.c = a;
delete o.c;    //删除对象o的属性a
console.log(o.c);     // undefined
console.log(a.pro);   // zhenn

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

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


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

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


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

这下应该真相大白了。

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


var a = 1;
delete a;
alert(a); // 1
 
function fn(){ return 42; }
delete fn;
alert(fn());  // 42
 
b = 2;
delete b;
alert(b);  // b is not defined;

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

标签:JavaScript,delete,操作符
0
投稿

猜你喜欢

  • Centos 6.4源码安装mysql-5.6.28.tar.gz教程

    2024-01-25 09:39:58
  • PHP实现PDF转图片的方法详解

    2023-05-26 19:59:51
  • 使用字符串建立查询能加快服务器的解析速度吗?

    2010-07-14 21:03:00
  • Python处理mysql特殊字符的问题

    2024-01-17 01:28:38
  • mysql随机查询若干条数据的方法

    2024-01-20 17:41:02
  • python可变对象,不可变对象详解

    2023-10-18 05:14:25
  • vue项目中如何调用多个不同的ip接口

    2024-04-10 10:32:37
  • Python爬虫突破反爬虫机制知识点总结

    2021-09-17 12:38:22
  • 如何查询Top N及Top(M―N)记录?

    2009-11-11 20:03:00
  • 利用python实现数据分析

    2023-01-05 22:07:27
  • Python利用Beautiful Soup模块搜索内容详解

    2023-10-24 15:53:43
  • Python开发桌面小程序功能

    2023-07-01 14:46:59
  • Python通过文本和图片生成词云图

    2023-08-03 09:39:35
  • php for 循环语句使用方法详细说明

    2023-11-17 21:43:21
  • Django 配置多站点多域名的实现步骤

    2022-05-23 23:53:46
  • oracle中变长数组varray,嵌套表,集合使用方法

    2024-01-20 19:51:19
  • 联动选择菜单(二级联动菜单 三 级联动菜单)

    2023-06-26 22:37:55
  • 配置高可用性的MySQL服务器负载均衡群集

    2009-01-04 12:43:00
  • 解决Python传递中文参数的问题

    2021-04-10 09:00:07
  • python缩进区别分析

    2022-05-18 00:37:50
  • asp之家 网络编程 m.aspxhome.com