json取值(key是中文或者数字)方式详解

先准备一个json对象用于演示

var json = {'name':'zhangsan', '年龄':23, 404:'你可能迷路了'};
  1. 使用JS中with关键字

     with(json) {
         console.log(name);//输出:zhangsan
         console.log(年龄);//输出:23
         console.log(404);//输出:404,用这种方法读取key是数字的属性,有问题
     }
  2. 最常见的传统的读取key

     console.log(json.name);//输出:zhangsan
     //key是中文也是支持的
     console.log(json.年龄);//输出:23
     //key是Number类型或者String类型的数字都不能这么读取
     console.log(json.404);//报错
  3. 通用万能型:json['key']

     console.log(json['name']);/输出:zhangsan
     console.log(json['年龄']);//输出:23
     console.log(json['404']);//输出:你可能迷路了
  4. json[key]

     console.log(json[name]);/输出:undefinded
     console.log(json[年龄]);//报错
     console.log(json[404]);//输出:你可能迷路了

json处理动态key方式

先准备案例对象

var jsonArr = [
    {"id": "1", "name": "A1"},
    {"id": "2", "name": "A2"},
    {"id": "3", "name": "A3"},
    {"id": "4", "name": "A4"},
    {"id": "5", "name": "A5"}
]
  1. 如果数据量不大,偶尔查询一次,使用for...in遍历
  2. 如果数据量大,经常使用,建立查找表提升性能

     //创建一个查找表函数
     function createLookMap(field) {
         var map = {};//创建一个空的json对象
         for (var i = 0; i < jsonArr.length; i++) {
             var value = jsonArr[i];//将数组中的元素作为json对象的值
             var key = value[field];//选取一个属性作为新的json对象的key
             map[key] = value;
         }
         return map;
     }

自测用例

var json={ 
100 : 1001,
epik : 'epik1',
匡正 : '匡正1',
// '100' : '100',
// 'epik' : 'epik',
// '匡正' : '匡正'
}

console.log(json['100']);
// console.log(json.100);//报错
console.log(json[100]);

console.log(json['epik'])
console.log(json.epik);
// console.log(json[epik]); //报错

console.log(json['匡正']); 
console.log(json.匡正);
// console.log(json[匡正]);//报错

用例总结:

1,定义json的键时,加不加引号效果一样;

2,取json的建时,

  万能:[''],

  数字可以 []和[''],(.会报错)

  字符可以 .和['']  ([]会报错)

posted @ 2018-12-20 16:04  小匡程序员  阅读(5151)  评论(0编辑  收藏  举报