2017-04-03 137 views
2

如果代码或数据本身出现问题,需要一些帮助。虽然我怀疑它的代码,因为我想验证我收到的格式正确的JSON数据...使用parseJSON解析JSON字符串时出错

这里是我的JSON数据

{"view":"cities","model":{"top10Cities":[{"id":1024,"name":"Mumbai (Bombay)","countrycode":"IND","district":"Maharashtra","population":"10500000"},{"id":2331,"name":"Seoul","countrycode":"KOR","district":"Seoul","population":"9981619"},{"id":206,"name":"São Paulo","countrycode":"BRA","district":"São Paulo","population":"9968485"},{"id":1890,"name":"Shanghai","countrycode":"CHN","district":"Shanghai","population":"9696300"},{"id":939,"name":"Jakarta","countrycode":"IDN","district":"Jakarta Raya","population":"9604900"},{"id":2822,"name":"Karachi","countrycode":"PAK","district":"Sindh","population":"9269265"},{"id":3357,"name":"Istanbul","countrycode":"TUR","district":"Istanbul","population":"8787958"},{"id":2515,"name":"Ciudad de México","countrycode":"MEX","district":"Distrito Federal","population":"8591309"},{"id":3580,"name":"Moscow","countrycode":"RUS","district":"Moscow (City)","population":"8389200"},{"id":3793,"name":"New York","countrycode":"USA","district":"New York","population":"8008278"}],"fusionCharts":{"chart":"{\"showValues\":\"0\",\"caption\":\"Cities by Country Code\",\"theme\":\"zune\"}","data":"[{\"label\":\"Mumbai (Bombay)\",\"value\":\"10500000\"},{\"label\":\"Seoul\",\"value\":\"9981619\"},{\"label\":\"São Paulo\",\"value\":\"9968485\"},{\"label\":\"Shanghai\",\"value\":\"9696300\"},{\"label\":\"Jakarta\",\"value\":\"9604900\"},{\"label\":\"Karachi\",\"value\":\"9269265\"},{\"label\":\"Istanbul\",\"value\":\"8787958\"},{\"label\":\"Ciudad de México\",\"value\":\"8591309\"},{\"label\":\"Moscow\",\"value\":\"8389200\"},{\"label\":\"New York\",\"value\":\"8008278\"}]"}},"cleared":false} 

这是我用来接收JSON代码数据

$(document).ready(function() { 

    var jsonD = $.getJSON("http://localhost:8080/v1/cityData", function (data) { 
     console.log("Success "+ data.toString()); 
     alert(data); 

     $("#fChart").insertFusionCharts({ 
      type: "column2d", 
      width: "450", 
      height: "250", 
      dateFormat: "JSONURL", 
      dataSource: data 
     }); 
    }) 

}); 

我试过这个article上说的提示,但它仍然不工作。有关如何解决这个问题的任何建议?由Nisanth建议,但图表库仍然没有工作由于

更新2

修改jQuery代码。它说无效的数据,也许这是融合图表库本身的问题?

$(document).ready(function() { 

var jsonD = {}; 

     $.getJSON("http://localhost:8080/v1/cityData", function (data) { 

      console.log("Success "); 
      alert(data); 
      jsonD = data; 

     }).done(function() { 

      var fcData = JSON.stringify(jsonD); 
      console.log("fcData: "+fcData); 
      $("#fChart").insertFusionCharts({ 
       type: "column2d", 
       width: "450", 
       height: "250", 
       dateFormat: "JSON", 
       dataSource: fcData 
      }); 
     });  
    }); 

的代码工作正常,我添加了一个日志.done函数中,它显示fcData的值见下文。

enter image description here

更改fcData = jsonD.model.fusionCharts和接收下面的错误。

Uncaught TypeError: b.match is not a function 
    at Fb (fusioncharts.js:214) 
    at constructor._drawCategory (fusioncharts.js:1263) 
    at constructor._drawComponents (fusioncharts.js:1223) 
    at constructor.draw (fusioncharts.js:1220) 
    at k._drawAxis (fusioncharts.js:981) 
    at k._updateVisuals (fusioncharts.js:976) 
    at k.draw (fusioncharts.js:979) 
    at k.init (fusioncharts.js:946) 
    at Object.m.createChart (fusioncharts.js:875) 
    at n.core.render (fusioncharts.js:1801) 

更新3

代码更新

}).done(function() {   
     var cfChart= jsonD.model.fusionCharts.chart; 
     var cfData= jsonD.model.fusionCharts.chart; 
     $("#fChart").insertFusionCharts({ 
      type: "column2d", 
      width: "450", 
      height: "250", 
      dateFormat: "JSON", 
      dataSource: {chart:cfChart,data:cfData} 
     }); 
    });  
}); 

错误日志

Uncaught TypeError: b.match is not a function 
    at Fb (fusioncharts.js:214) 
    at constructor._drawCategory (fusioncharts.js:1263) 
    at constructor._drawComponents (fusioncharts.js:1223) 
    at constructor.draw (fusioncharts.js:1220) 
    at k._drawAxis (fusioncharts.js:981) 
    at k._updateVisuals (fusioncharts.js:976) 
    at k.draw (fusioncharts.js:979) 
    at k.init (fusioncharts.js:946) 
    at Object.m.createChart (fusioncharts.js:875) 
    at n.core.render (fusioncharts.js:1801) 

工作代码

$(document).ready(function() { 

    var jsonD = {}; 

    $.getJSON("http://localhost:8080/v1/cityData", function (data) { 

     console.log("Success "); 
     //alert(data); 
     jsonD = data; 

    }).done(function() { 

     var cfChart= JSON.parse(jsonD.model.fusionCharts.chart); 
     var cfData= JSON.parse(jsonD.model.fusionCharts.data); 
     $("#fChart").insertFusionCharts({ 
      type: "column2d", 
      width: "450", 
      height: "250", 
      dateFormat: "JSON", 
      dataSource: {chart:cfChart,data:cfData} 
     }); 
    });  
}); 
+1

的'$ .getJSON()'函数不返回JSON字符串,它把它传递给你的回调函数中'data'参数。使用'data'从'$ .getJSON()'回调中调用'.insertFusioncharts()' - 注意到jQuery已经为您解析了JSON。 – nnnnnn

+0

@nnnnnnn我在$ .getJSON中移动它后,仍然收到相同的消息“[object Object]”,检查我的更新。 – dimas

+0

@dimas你没有将json转换为字符串。 Do:'var fcData = JSON.stringify(jsonD);' –

回答

2

像@nnnnnn在他的评论中提到的... $.getJSON不返回json。它总是返回一个Deferred Object

如果你想使用$.getJSON成功功能data你可以这样做:

//declaring in global scope 
var jsonD={}; 
$.getJSON("http://localhost:8080/v1/cityData", function (data) { 
    console.log("Success"); 
    alert(data); 
    //changing the value in local scope 
    jsonD = data; 
}).done(function(){ 
     var fcData = jsonD.model.fusionCharts; 
     $("#fChart").insertFusionCharts({ 
      type: "column2d", 
      width: "450", 
      height: "250", 
      dateFormat: "JSON", 
      dataSource: fcData 
     }); 
}) 

编辑

检查您的json数据我看到的数据没有正确提取。 FusionCharts期望JSON数据具有chartdata密钥。这个数据是出现在你的JSONdata.model.fusionChartsstring

所以,你必须首先extract他们,那么它解析到json,然后将它提供给你dataSource

所以,你设置会是这样的实际fusionChart

.done(function(){ 
      var cfChart= JSON.parse(jsonD.model.fusionCharts.chart); 
      var cfData= JSON.parse(jsonD.model.fusionCharts.data); 
      $("#fChart").insertFusionCharts({ 
       type: "column2d", 
       width: "450", 
       height: "250", 
       dateFormat: "JSON", 
       dataSource: {chart:cfChart,data:cfData} 
      }); 
    }) 
+0

在应用您所做的建议后,我仍然收到错误...我更新了代码并且发布了错误。 – dimas

+0

有一个错字..检查最近的更新,并尝试它! –

+0

现在图表正在显示!非常感谢你!希望我能给这个答案增加更多的观点。尽管现在对于你在数据源部分做了什么感到困惑。 – dimas