js中获取key得到某对象中相对应的value的方法:obj.key
js中根据动态key得到某对象中相对应的value的方法有二:
一、var key = "name1";var value = obj[key];
二、var key = "name1";var value = eval("obj."+key);
详细出处参考: http://www.jb51.net/article/46953.htm
- var obj={"name":"wjy","age":26,"sex":"female"};//定义一个object对象
- var keys=[];//定义一个数组用来接受key
- var values=[];//定义一个数组用来接受value
- for(var key in obj){
- keys.push(key);
- values.push(obj[key]);//取得value
- alert(eval("obj."+key));//循环内逐一打印value值
- }
- alert(obj.name);//wjy
- alert("keys is :"+keys+" and values is :"+values);
- //keys is : name,age,sex and values is : wjy,26,female
使用 for in 循环遍历对象的属性时, 原型链上的所有属性 都将被访问:
- Object.prototype.bar = 10;// 修改Object.prototype
- var obj={"name":"wjy","age":26,"sex":"female"};//定义一个object对象
- var keys=[];//定义一个数组用来接受key
- var values=[];//定义一个数组用来接受value
- for(var key in obj){
- keys.push(key);
- values.push(obj[key]);//取得value
- }
- alert("keys is :"+keys+" and values is :"+values);
- //keys is : name,age,sex,bar and values is : wjy,26,female,10
推荐总是使用 hasOwnProperty 方法, 这将会避免原型对象扩展带来的干扰:
- function allpro(obj){
- var keys=[];
- var values=[];
- for(var key in obj){
- //只遍历对象自身的属性,而不包含继承于原型链上的属性。
- if (obj.hasOwnProperty(key) === true){
- keys.push(key);
- values.push(obj[key]);
- }
- }
- alert("keys is :"+keys+" and values is :"+values);
- }
- Object.prototype.bar = 1;// 修改Object.prototype
- var o={"name":"wjy","age":26,"sex":"female"};//定义一个object对象
- allpro(o);
- //keys is : name,age,sex and values is: wjy,26,female
object对象没有length属性,那么获取object对象的length就可以通过遍历得到key值的数组的长度来获取啦~