(转)JavaScript: in, hasOwnProperty, delete, for/in

in 运算符

判断对象是否拥有某一属性
只要对象拥有该属性,就会返回true,否则false

var point = { x:1, y:1 };
alert( ‘x‘ in point );  //true

var arr = [‘one‘, ‘two‘];
alert( ‘kang‘ in arr );  //false
alert( ‘1‘ in arr );  //true
alert( ‘push‘ in arr );  //true

var fn = function(){};
fn.prototype.site = ‘cnblogs.com‘;
var obj = new fn();
alert( ‘site‘ in obj );  //true

hasOwnProperty

判断对象是否具有某一属性。这个属性必须是自己具有的,即非继承的。

var o = {};
o.name = ‘object‘;
alert( o.hasOwnProperty(‘kang‘) );    //false: 不存在
alert( o.hasOwnProperty(‘toString‘) );    //false: ‘toString‘方法继承自‘Object‘
alert( o.hasOwnProperty(‘name‘) ); //true

alert( Math.hasOwnProperty("kang") ); //false
alert( Math.hasOwnProperty("cos") ); //true;
alert( Math.hasOwnProperty("toString") );  //false: ‘toString‘方法继承自‘Object‘

var base = function(){
    this.name = ‘Rain Man‘;
};
base.prototype.site = ‘cnblogs.com‘;
var o = new base();
alert( o.hasOwnProperty(‘site‘) ); //false: 是继承的
alert( o.hasOwnProperty(‘name‘) ); //true

delete 运算符

删除对象的属性,删除后不能使用 for/in 枚举出删除的属性。
删除数组的元素,删除后数组的 length 不会改变,不可以使用 for/in 枚举出来删除的元素; shift()、pop()、splice()才会真正的删除数组中的元素

var point = { x:1, y:1 };
delete point.x;  //{ y:1 }

var arr = [‘one‘, ‘two‘];
delete arr[0];  //[undefined, ‘two‘]

for/in

枚举对象的属性
对象的一些属性是不可以使用for/in来输出的,例如:内部的,用户自定义的可以,从构造函数prototype中继承的也可以枚举出

var arr = [‘one‘, ‘two‘];
arr.author = ‘rainman‘;
//不会枚举出数组的push,pop等方法,因为这些方法都是内部的
for( var i in arr ) ist(arr[i]);    //‘one‘、‘two‘、‘rainman‘

var Blog = function(){};
Blog.prototype.site = ‘cnblogs.com‘;
var oBlog = new Blog();
for( var i in oBlog ) ist(oBlog[i]); //‘cnblogs.com‘

var RM = function(){};
RM.prototype = new Blog();
RM.prototype.url = ‘http://rainman.cnblogs.com‘
var oRM = new RM();

for( var i in oRM ){
    ist(i + ‘:‘+ oRM[i]); //‘url:http://rainman.cnblogs.com‘、site:cnblogs.com
}

时间: 2024-10-05 16:12:37

(转)JavaScript: in, hasOwnProperty, delete, for/in的相关文章

深入理解javascript 中的 delete(转)

在这篇文章中作者从<JavaScript面向对象编程指南>一书中关于 delete 的错误讲起,详细讲述了关于 delete 操作的实现, 局限以及在不同浏览器和插件(这里指 firebug)中的表现. 下面翻译其中的主要部分. ...书中声称 “函数就像一个普通的变量那样——可以拷贝到不同变量,甚至被删除” 并附上了下面的代码片段作为说明: >>> var sum = function(a, b) {return a+b;}; >>> var add =

Javascript中的delete

一.问题的提出 我们先来看看下面几段代码,要注意的是,以下代码不要在浏览器的开发者工具(如FireBug.Chrome Developer tool)中运行,原因后面会说明: 为什么我们可以删除对象的属性: 复制代码代码如下: var o = { x: 1 }; delete o.x; // true o.x; // undefined 但不以删除像这样声明的变量: 复制代码代码如下: var x = 1; delete x; // false x; // 1 也不能删除像这样定义的函数: 复制

关于JavaScript中的delete操作

关于JavaScript中的delete操作 看到一道题,是这样的: (function(x){ delete x; return x; })(1); 1 null undefined Error 我选了Error....,然而是错的,运行了一下,答案是1. 难道不能delete函数中的参数吗?什么情况是可以delete的?什么情况是不可以delete的? 去网上查了一下 通常:delete 操作符用来删除一个对象的属性. 语法:delete expression 如果成功返回true,失败返回

Javascript 中的 in, hasOwnProperty, delete, for/in

in 运算符 判断对象是否拥有某一属性只要对象拥有该属性,就会返回true,否则false var point = { x:1, y:1 };alert( 'x' in point );  //true var arr = ['one', 'two'];alert( 'kang' in arr );  //falsealert( '1' in arr );  //truealert( 'push' in arr );  //true var fn = function(){};fn.protot

理解JAVASCRIPT 中hasOwnProperty()和isPrototypeOf的作用

hasOwnProperty:是用来判断一个对象是否有你给出名称的属性或对象.不过需要注意的是,此方法无法检查该对象的原型链中是否具有该属性,该属性必须是对象本身的一个成员.格式如下: 1. 示例一: var bStr = "Test String".hasOwnProperty("split"); // 得到false, 因为不能检测原型链中的属性 "Test String".split(" ");//但是是能成功调用的 2

javascript 中的 delete

那么,为什么我们能删除一个对象的属性: var x = { a: 1 }; delete x.a; // true x.a; // undefined 但却不能删除一个变量: var x = 1; delete x; // false; x; // 1 也不能删除一个函数: function x() {}; delete x; // false; typeof x; // "function" 注意:delete 只有当一个属性无法被删除时才返回 false. 每一个属性拥有零至多个如

javascript delete机制学习

想了解delete的机制缘起一个现象,我无法解释,也无法理解. 首先看一下下面这个例子: ? 1 2 var x = 1; delete x; //false 然后我又执行了一次: ? 1 2 y = 2; delete y; //true 看到上面的结果,我比较吃惊,为什么同样是删除,区别怎么这么大呢?进而我想学习和了解一下JS delete的机制. 在MDN(Mozilla Developer Network)上看到下面一个例子 ? 1 2 3 4 5 6 7 8 9 10 11 12 13

Javascript的变量与delete操作符

原文:http://charlee.li/javascript-variables-and-delete-operator.html 刚刚看到一篇好文(原文链接), 对Javascript中的delete操作符分析得很透彻.在这里简单地介绍一下内容. 虽然是一个小小的delete操作符,其行为却异常复杂. # Javascript的变量 实际上Javascript中,变量 = 对象属性,这是因为 Javascript 在执行脚本之前 会创建一个Global对象,所有的全局变量都是这个Global

JavaScript delete用法,属性,特性,执行上下文,激活对象 综合篇

一.问题的提出 我们先来看看下面几段代码,要注意的是,以下代码不要在浏览器的开发者工具(如FireBug.Chrome Developer tool)中运行,原因后面会说明: 为什么我们可以删除对象的属性: var o = { x: 1 }; delete o.x; // true o.x; // undefined 但不以删除像这样声明的变量: var x = 1; delete x; // false x; // 1 也不能删除像这样定义的函数: function x(){} delete