Movatterモバイル変換


[0]ホーム

URL:


codecamp

JavaScript中字符串(string)转json的方法

JavaScript:字符串(string)转换为json

第一种方法:

使用js函数eval();

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

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

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

js代码:

代码如下:

function ConvertToJsonForJs() {  //var testJson = "{ name: '小强', age: 16 }";(支持)  //var testJson = "{ 'name': '小强', 'age': 16 }";(支持)  var testJson = '{ "name": "小强", "age": 16 }';  //testJson=eval(testJson);//错误的转换方式  testJson = eval("(" + testJson + ")");  alert(testJson.name);  }

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

jquery.parseJSON()  js:代码  代码如下:  function ConvertToJsonForJq() {  var testJson = '{ "name": "小强", "age": 16 }';  //不知道  //'{ name: "小强", age: 16 }' (name 没有使用双引号包裹)  //"{ 'name': "小强", 'age': 16 }"(name使用单引号)  testJson = $.parseJSON(testJson);  alert(testJson.name);  }

很多时候我们需要组装字符串为json对象,首先要组合字符串,然后转换为json对象

例子:

var convertStringToJSON = function(){    var str="{'ID':12,'Name':'Tom','Age':21}";    var stu = eval('('+str+')');    alert(stu.Name);}

上面代码执行后会弹出“Tom”,说明已经成功转换为json对象了。 

创建XMLHTTPRequest:

<script language="javascript" type="text/javascript">var request;function createRequest() {  try {    request = new XMLHttpRequest();  } catch (trymicrosoft) {    try {      request = new ActiveXObject("Msxml2.XMLHTTP");    } catch (othermicrosoft) {      try {        request = new ActiveXObject("Microsoft.XMLHTTP");      } catch (failed) {        request = false;      }    }  }  if (!request)    alert("Error initializing XMLHttpRequest!");}function getCustomerInfo() {  createRequest();  // Do something with the request variable}</script>
javascript中JSON对象与JSON字符串相互转换实例
JavaScript将XML转成JSON的方法
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录
关于 JSON

JSON 教程

JSON 基础

json格式

JSON 示例

JSON解析

JSON遍历

JSON调用

JSON转换

JSON获取

JSON字符串

JSON数组

关闭

MIP.setData({'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false},'pageFontSize' : getCookie('pageFontSize') || 20});MIP.watch('pageTheme', function(newValue){setCookie('pageTheme', JSON.stringify(newValue))});MIP.watch('pageFontSize', function(newValue){setCookie('pageFontSize', newValue)});function setCookie(name, value){var days = 1;var exp = new Date();exp.setTime(exp.getTime() + days*24*60*60*1000);document.cookie = name + '=' + value + ';expires=' + exp.toUTCString();}function getCookie(name){var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)');return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null;}
[8]ページ先頭

©2009-2025 Movatter.jp