当前位置: 首页 > 图文教程 > 网络编程 > Javascript > JavaScript delete 属性的使用

Javascript
脚本收藏iframe
自适应图片大小的弹出窗口
Prototype1.4手册
3张图片循环组和(很有动感)
图片加载进度实时显示
收藏一个代码
点击变化图象 不错
去除链接虚线全面分析总结
如何用JS取得网址中的文件名
新页面打开实际尺寸的图片
js的event详解。
js输入中文效果
图片完美缩放
图片自动更新(说明)
Ajax Blog 用到的几个函数
js几个不错的函数 $$()
菜单效果
yahoo 页面的标签效果
Ucren Virtual Desktop V2.0
一段非常简单的让图片自动切换js代码

Javascript 中的 JavaScript delete 属性的使用


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-10   浏览: 171 ::
收藏到网摘: n/a

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')