对象属性键值[key]属性问题

您所在的位置:网站首页 value属性值为1 对象属性键值[key]属性问题

对象属性键值[key]属性问题

#对象属性键值[key]属性问题| 来源: 网络整理| 查看: 265

其实我是想动态给key赋值,然后得到key为多少所对就的值。但这种做法行不通,obj.key会去找obj下key为"key"所对应的值,结果当然是找不到喽。 于是,我想到了js中遍历对象属性的方法:

function printObject(obj){ //obj = {"cid":"C0","ctext":"区县"}; var temp = ""; for(var i in obj){//用javascript的for/in循环遍历对象的属性 temp += i+":"+obj[i]+"\n"; } alert(temp);//结果:cid:C0 \n ctext:区县 }

 

这样,就可以清楚的知道js中一个对象的key和value分别是什么了。 回到刚才的问题,怎么动态给key赋值,然后以obj.key的方式得到对应的value呢? 其实以上printObject中有提示,那就是用obj[key]的方法,key可以是动态的,这样就解决了我上面提出的问题了。 最后说一下,还有一个方法也可以,那就是:eval("obj."+key)。

总结: js中想根据动态key得到某对象中相对应的value的方法有两个(⊙o⊙)哦: 一、var key = "name1";var value = obj[key]; 二、var key = "name1";var value = eval("obj."+key);

栗子:

var obj={"name":"tom","age":22,"job":"it"}; var keys="name"; console.log(obj[keys]); //tom console.log(eval("obj."+keys)); //tom JS获取JSON对象中的KEY和VALUE var json= { "Type": "Coding", "Height":100 }; for (var key in json) { alert(key); //Type, Height alert(json[key]); //Coding, 100 } $.each(json, function(i) { alert(json[i]); //Coding, 100 alert(i); //Type, Height });

 



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3