JavaScript中诡异的delete操作符
网络编程 2021-07-04 21:47www.168986.cn编程入门
这篇文章主要介绍了JavaScript中诡异的delete操作符,本文讲解了删除对象的属性、对数组的操作、对于变量的操作等内容,需要的朋友可以参考下
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特性,无法被删除。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程