JavaScript delete 属性的使用
更新时间:2009年10月08日 18:04:34 作者:
JavaScript对象数据结构基本形式:{ key : value},其中key:value就为对象的一个属性,key作为属性名称,value为属性值,这值可以是任何JavaScript数据类型。
delete 是删除对象的一个属性,例如对于一个对象,
var obj = {key:5};
delete obj.key就是删除该对象的key属性,这个没什么问题,但当对象的原型prototype对象也存在该属性时,就值得注意了。
var A = function(){};
A.prototype.testMe = true;
var a = new A();
//覆盖原型属性
a.testMe = true;
if(a.testMe){
// 一些关键代码...
// ....
//删除这属性
delete a.testMe;
}
//第二段 ---------------------------
// 在其它模块中
if(a.testMe){
// 一些关键代码...
// ....
}
第二段是值得注意的,不要以为a中testMe已尼删除了就不存在了,所以a.testMe就为undefined,即为假,其实它通过原型访问还是存在的,还是true!
这里不留神就中招了。
//附:
检测对象是否存在某属性, 包括原型链的:
if ('attrName' in obj)…
检测对象是否存在某属性,是对象本身的,而非原型链的:
obj.hasOwnProperty('attrName')
var obj = {key:5};
delete obj.key就是删除该对象的key属性,这个没什么问题,但当对象的原型prototype对象也存在该属性时,就值得注意了。
复制代码 代码如下:
var A = function(){};
A.prototype.testMe = true;
var a = new A();
//覆盖原型属性
a.testMe = true;
if(a.testMe){
// 一些关键代码...
// ....
//删除这属性
delete a.testMe;
}
//第二段 ---------------------------
// 在其它模块中
if(a.testMe){
// 一些关键代码...
// ....
}
第二段是值得注意的,不要以为a中testMe已尼删除了就不存在了,所以a.testMe就为undefined,即为假,其实它通过原型访问还是存在的,还是true!
这里不留神就中招了。
//附:
检测对象是否存在某属性, 包括原型链的:
if ('attrName' in obj)…
检测对象是否存在某属性,是对象本身的,而非原型链的:
obj.hasOwnProperty('attrName')
您可能感兴趣的文章:
- JavaScript中诡异的delete操作符
- js delete 用法(删除对象属性及变量)
- Javascript中的delete介绍
- javascript delete 使用示例代码
- JavaScript从数组中删除指定值元素的方法
- Javascript根据指定下标或对象删除数组元素
- js 删除数组的几种方法小结
- js删除数组元素、清空数组的简单方法(必看)
- js删除Array数组中指定元素的两种方法
- 基于JavaScript实现移除(删除)数组中指定元素
- Javascript remove 自定义数组删除方法
- javascript中删除指定数组中指定的元素的代码
- JavaScript使用delete删除数组元素用法示例【数组长度不变】
最新评论