jQuery.parseJSON 函数提供了解析的支持, 详细的说明见这里。
var obj = jQuery.parseJSON('{"name":"John"}'); alert( obj.name === "John" );
使用对象生成 JSON 格式串
在 jQuery 中并没有提供直接将普通的 JavaScript 对象转换为 JSON 串的方法,可以使用下面的扩展库来完成。
jquery-json 扩展库
这个库用来扩展 jQuery ,对于 JSON 的使用,扩展了两个方法。
toJSON 方法用来将一个普通的 JavaScript 对象序列化为 JSON 串。
var thing = {plugin: 'jquery-json', version: 2.3}; var encoded = $.toJSON( thing ); // '{"plugin":"jquery-json","version":2.3}'
evalJSON 方法将一个 JSON 串解析为一个普通的 JavaScript 对象。
var thing = {plugin: 'jquery-json', version: 2.3}; var encoded = $.toJSON( thing ); // '{"plugin":"jquery-json","version":2.3}' var name = $.evalJSON( encoded ).plugin; // "jquery-json" var version = $.evalJSON(encoded).version; // 2.3
以下是我一直发送失败,加了$.toJSON(senddata)后马上就成功了。使用$.toJSON需要一个jQuery插件,见附件。
var user=new Object(); user.email = email; user.first_name = firstName; user.last_name = lastName; user.password = password; var senddata = {}; senddata.user=user; senddata.api_key=levelup_api_key; // log(JSON.stringify(senddata)); var encoded = $.toJSON(senddata); $.ajax({ type: "POST", url: levelup_register,//url data: encoded, headers: { 'Accept': 'application/json', 'Content-Type': 'application/json', }, beforeSend: function() {$.mobile.showPageLoadingMsg();}, complete: function() {$.mobile.hidePageLoadingMsg();}, success: function(data){ doSignInLevelUp_base(email,password); }, error: function(error){ // log(JSON.stringify(error)); showAlert(error.status+":"+error.statusText); } });