Rumah > hujung hadapan web > tutorial js > javascript如何获取对象并复制对象实现用法详解

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

伊谢尔伦
Lepaskan: 2017-07-21 13:37:42
asal
1308 orang telah melayarinya

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

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

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

var obj={ colkey: "col", colsinfo: "NameList" }
Salin selepas log masuk

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

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

其实这种方式有一定的限制,关键是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 属性不考虑原型链中的对象。

Atas ialah kandungan terperinci javascript如何获取对象并复制对象实现用法详解. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan