JavaScript中诡异的delete操作符


Posted in Javascript onMarch 12, 2015

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 相关文章推荐
splice slice区别
Oct 09 Javascript
javascript 事件处理示例分享
Dec 31 Javascript
javascript实现不同颜色Tab标签切换效果
Apr 27 Javascript
Javascript自执行匿名函数(function() { })()的原理浅析
May 15 Javascript
AngularJs expression详解及简单示例
Sep 01 Javascript
Bootstrap 3.x打印预览背景色与文字显示异常的解决
Nov 06 Javascript
react-native组件中NavigatorIOS和ListView结合使用的方法
Sep 30 Javascript
Angular6 写一个简单的Select组件示例
Aug 20 Javascript
微信小程序实现的一键连接wifi功能示例
Apr 24 Javascript
BootStrap前端框架使用方法详解
Feb 26 Javascript
JS数组的常用10种方法详解
May 08 Javascript
js实现手表表盘时钟与圆周运动
Sep 18 Javascript
JavaScript实现计算字符串中出现次数最多的字符和出现的次数
Mar 12 #Javascript
jquery实现页面关键词高亮显示的方法
Mar 12 #Javascript
JavaScript设计模式学习之“类式继承”
Mar 12 #Javascript
鼠标事件的screenY,pageY,clientY,layerY,offsetY属性详解
Mar 12 #Javascript
JavaScript中return false的用法
Mar 12 #Javascript
JavaScript中神奇的call()方法
Mar 12 #Javascript
jquery实现无限分级横向导航菜单的方法
Mar 12 #Javascript
You might like
PHP截取汉字乱码问题解决方法mb_substr函数的应用
2008/03/30 PHP
laravel5创建service provider和facade的方法详解
2016/07/26 PHP
thinkphp3.2实现在线留言提交验证码功能
2017/07/19 PHP
JavaScript脚本性能优化注意事项
2008/11/18 Javascript
Jquery加载时从后台读取数据绑定到dropdownList实例
2013/06/09 Javascript
js获取上传文件大小示例代码
2014/04/10 Javascript
node.js中实现同步操作的3种实现方法
2014/12/05 Javascript
jQuery插件jquery-barcode实现条码打印的方法
2015/11/25 Javascript
Nodejs多站点切换Htpps协议详解及简单实例
2017/02/23 NodeJs
vue.js如何将echarts封装为组件一键使用详解
2017/10/10 Javascript
JS实现匀速与减速缓慢运动的动画效果封装示例
2018/08/27 Javascript
Node.js + express基本用法教程
2019/03/14 Javascript
mpvue微信小程序开发之实现一个弹幕评论
2019/11/24 Javascript
原生js实现密码强度验证功能
2020/03/18 Javascript
vue-cli设置publicPath小记
2020/04/14 Javascript
react使用CSS实现react动画功能示例
2020/05/18 Javascript
使用PYTHON创建XML文档
2012/03/01 Python
Python计算程序运行时间的方法
2014/12/13 Python
Python中实现参数类型检查的简单方法
2015/04/21 Python
Python可视化mhd格式和raw格式的医学图像并保存的方法
2019/01/24 Python
Pandas将列表(List)转换为数据框(Dataframe)
2020/04/24 Python
pycharm 对代码做静态检查操作
2020/06/09 Python
如何用Python提取10000份log中的产品信息
2021/01/14 Python
关于解决iframe标签嵌套问题的解决方法
2020/03/04 HTML / CSS
美国克罗格超市在线购物:Kroger
2019/06/21 全球购物
大学生优秀自荐信范文
2014/02/25 职场文书
人事专员岗位职责范本
2014/03/04 职场文书
销售会计岗位职责
2014/03/15 职场文书
出国英文推荐信
2014/05/10 职场文书
男性健康日的活动方案
2014/08/18 职场文书
企业党建工作汇报材料
2014/08/19 职场文书
个人四风问题整改措施
2014/10/24 职场文书
群众路线学习笔记范文
2014/11/06 职场文书
南阳市白酒市场的调查报告
2019/11/08 职场文书
Kubernetes控制节点的部署
2022/04/01 Servers
Win11显卡控制面板打开显卡设置方法
2022/04/20 数码科技