首页  >  文章  >  web前端  >  javascript如何获取对象并复制对象实现用法详解

javascript如何获取对象并复制对象实现用法详解

伊谢尔伦
伊谢尔伦原创
2017-07-21 13:37:421227浏览

了解一个JS对象的所有属性和方法,获得一个对象的所有属性和方法,核心代码和原理如下:

function displayProp(obj){  
  var names="";   
  for(var name in obj){   
    names+=name+": "+obj[name]+", "; 
  } 
  alert(names); 
}

如果知道这个对象的所有属性自然就可以重新new一个,然后对每个属性赋值,就可以做到,但如果不知道呢?如何创建一个内容相同 的对象呢? 

var obj={ colkey: "col", colsinfo: "NameList" }

最简单就是使用for in, 
例如obj2就拥有了和obj完全相同的属性 

var obj2=new Object(); 
for(var p in obj) 
{ 
var name=p;//属性名称 
var value=obj[p];//属性对应的值 
obj2[name]=obj[p]; 
}

其实这种方式有一定的限制,关键是js中for in有一定限制,并不会遍历对象的所有属性,只会遍历可枚举的属性,由js核心定义的方法都是不可枚举的,例如tostring(),但代码中定义的属性都是可枚举的(可以通过特殊定义为不可枚举的)。因此这个方法就够用了。 
一个对象是否可以进行for in穷举,我们可以通过propertyIsEnumerable属性来判断,说明如下: 
propertyIsEnumerable 属性 
返回 Boolean 值,指出所指定的属性是否为一个对象的一部分以及该属性是否是可列举的。 
object.propertyIsEnumerable(proName) 
参数 
object 
必选项。一个对象。 
proName 
必选项。一个属性名称的字符串值。 
说明 
如果 proName 存在于 object 中且可以使用一个 For…In 循环穷举出来,那么 propertyIsEnumerable 属性返回 true。如果 object 不具有所指定的属性或者所指定的属性不是可列举的,那么 propertyIsEnumerable 属性返回 false。典型地,预定义的属性不是可列举的,而用户定义的属性总是可列举的。 
propertyIsEnumerable 属性不考虑原型链中的对象。

以上是javascript如何获取对象并复制对象实现用法详解的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn