Javascript delete 引用类型对象_javascript技巧
程序员文章站
2022-06-01 17:57:28
...
如下面例子:
var testVar = {
a : {
test : 1
}
},
test1 = {},
test2 = {};
test1.a = testVar.a;
test2.a = testVar.a;
/*
delete test1.a;
console.log(test1.a); // undefined
console.log(test2.a); // Object {test: 1}
console.log(testVar.a); // Object {test: 1}
*/
delete testVar.a;
console.log(test1.a); // Object {test: 1}
console.log(test2.a); // Object {test: 1}
console.log(testVar.a); // undefined
复制代码 代码如下:
var testVar = {
a : {
test : 1
}
},
test1 = {},
test2 = {};
test1.a = testVar.a;
test2.a = testVar.a;
/*
delete test1.a;
console.log(test1.a); // undefined
console.log(test2.a); // Object {test: 1}
console.log(testVar.a); // Object {test: 1}
*/
delete testVar.a;
console.log(test1.a); // Object {test: 1}
console.log(test2.a); // Object {test: 1}
console.log(testVar.a); // undefined
通过测试可以看出,javascript的delete删除的对象如果是一个引用类型,那它删除的不是引用的对象,而是指向该引用对象的指针。因此,即使 delete testVar.a ,test1.a指向的对象仍然没有删除。
更多关于javascript delete关键字的原理,推荐:
http://perfectionkills.com/understanding-delete/
翻译版本:
下一篇: [20130706]传说中的中断风暴
推荐阅读
-
从URL中提取参数与将对象转换为URL查询参数的实现代码_javascript技巧
-
探讨javascript是不是面向对象的语言_javascript技巧
-
网页运行时提示对象不支持abigimage属性或方法_javascript技巧
-
遍历DOM对象内的元素属性示例代码_javascript技巧
-
关于JavaScript对象的动态选择及遍历对象_javascript技巧
-
JavaScript 嵌套函数指向this对象错误的解决方法_javascript技巧
-
JavaScript词法作用域与调用对象深入理解_javascript技巧
-
javascript包装对象实例分析_javascript技巧
-
js定义对象或数组直接量时各浏览器对多余逗号的处理(json)_javascript技巧
-
一页面多XMLHttpRequest对象_javascript技巧