JSON格式数据的js操作

第一种方式:

使用js函数eval();

testJson=eval(testJson);是错误的转换方式。

正确的转换方式需要加(): testJson = eval("(" + testJson + ")");

eval()的速度非常快,但是他可以编译以及执行任何javaScript程序,所以会存在安全问题。在使用eval()。来源必须是值得信赖的。需要使用更安全的json解析器。在服务器不严格的编码在json或者如果不严格验证的输入,就有可能提供无效的json或者载有危险的脚本,在eval()中执行脚本,释放恶意代码。

js代码:

 

[javascript] view plaincopy
 
  1. function ConvertToJsonForJs() {  
  2.           //var testJson = "{ name: ‘小强‘, age: 16 }";(支持)  
  3.           //var testJson = "{ ‘name‘: ‘小强‘, ‘age‘: 16 }";(支持)  
  4.           var testJson = ‘{ "name": "小强", "age": 16 }‘;  
  5.           //testJson=eval(testJson);//错误的转换方式  
  6.           testJson = eval("(" + testJson + ")");  
  7.           alert(testJson.name);  
  8.       }  

 

第二种方式使用jquery.parseJSON()方法对json的格式要求比较高,必须符合json格式

jquery.parseJSON()

js:代码

 

[c-sharp] view plaincopy
 
  1. function ConvertToJsonForJq() {  
  2.           var testJson = ‘{ "name": "小强", "age": 16 }‘;  
  3.           //不知道  
  4.           //‘{ name: "小强", age: 16 }‘ (name 没有使用双引号包裹)  
  5.           //"{ ‘name‘: "小强", ‘age‘: 16 }"(name使用单引号)  
  6.           testJson = $.parseJSON(testJson);  
  7.           alert(testJson.name);  
  8.       }  

 

===========================================================================================

第一种:使用for循环

js代码:

 

[javascript] view plaincopy
 
  1. function CyclingJson1() {  
  2.             var testJson = ‘[{ "name": "小强", "age": 16 },{"name":"小明","age":17}]‘;  
  3.             testJson = eval("(" + testJson + ")");  
  4.             for (var i = 0; i < testJson.length; i++) {  
  5.                 alert(testJson[i].name);  
  6.             }  
  7.         }  

 

 

第二种:使用关键字in

js代码:

 

[c-sharp] view plaincopy
 
  1. function CyclingJson2() {  
  2.            var testJson = ‘[{ "name": "小强", "age": 16 },{"name":"小明","age":17}]‘;  
  3.            testJson = eval("(" + testJson + ")");  
  4.            for (var i in testJson) {  
  5.                alert(testJson[i].name);  
  6.            }  
  7.        }  

 

第三种;使用jquery.each()函数

 

[javascript] view plaincopy
 
  1. function CyclingJson3() {  
  2.            var testJson = ‘[{ "name": "小强", "age": 16 },{"name":"小明","age":17}]‘;  
  3.            testJson = eval("(" + testJson + ")");  
  4.            $.each(testJson, function (i, n) {  
  5.                alert(i); //i为索引值   
  6.                alert(n.name); //n为遍历的值  
  7.            });  
  8.        }  

JSON格式数据的js操作

上一篇:购买了新书《Bootstrap用户手册—设计响应式网站》及简介Bootstrap是什么


下一篇:web端视频直播网站的弊端和优势