Ajax获取到数据放入echarts里不显示的原因分析及解决办法
程序员文章站
2022-07-02 18:15:29
在做一个需要用到echarts地图的项目的时候,成功通过ajax获取到了后台提供的数据,并生成了想要的json串。但是,放到echarts option.series[0]...
在做一个需要用到echarts地图的项目的时候,成功通过ajax获取到了后台提供的数据,并生成了想要的json串。但是,放到echarts option.series[0].data里,获取不到数据。在生成的地图上无法看到你从后台获取到的值。翻遍百度和必应,给出的答案五花八门,仍旧未解决问题,最后还是一个同事大牛给解决的,在此分享给大家。希望对大家有帮助,,,,
废话不多说,直接上码:
$(function () { var data = []; function setoption(data){ var mychart = echarts.init(document.getelementbyid('main')); //window.onresize = mychart.resize; var option = { title : { text: '全国...分布图', // subtext: '纯属虚构', x:'left' }, tooltip : { trigger: 'item' }, // legend: { // orient: 'vertical', // x:'left', // data:['iphone3','iphone4','iphone5'] // }, datarange: { min: 0, max: 10, x: 'left', y: 'bottom', text:['高','低'], // 文本,默认为数值文本 color:['#ff5e5e', '#ffa25e', '#ffd05e','#fce6b2','#e1dbcd'], calculable : true }, // toolbox: { // show: true, // orient : 'vertical', // x: 'right', // y: 'center', // feature : { // mark : {show: true}, // dataview : {show: true, readonly: false}, // restore : {show: true}, // saveasimage : {show: true} // } // }, // roamcontroller: { // show: true, // x: 'right', // maptypecontrol: { // 'china': true // } // }, series : [ { name: '...', type: 'map', maptype: 'china', roam: false, itemstyle:{ normal:{label:{show:true}}, emphasis:{label:{show:true}} }, data:data } ] }; mychart.setoption(option); //$.getjson('hotspotservlet',function(data){ //option.series[0].data=data.result; // 为echarts对象加载数据 //mychart.setoption(option); //}); } //获取...排行数据 function getmapdata(limit){ $.ajax({ url:'http://127.0.0.1/api/adminunit/score/top/'+limit, type:'post', datatype:'json', success:function(objdata){ //var str = json.parse(objdata); for(var i = 0;i < objdata.length;i ++){ var did = parseint(objdata[i].id); //var dname="天津市"; //if(did==1){ // dname="北京市"; //} var dname = objdata[i].name; var dscore = parseint(objdata[i].score); var onedata = {}; var onedata = {id:did,name:dname,value:dscore}; data.push(onedata); } console.log(data); //option.series[0].data=data; setoption(data);//执行setoption函数。传参 } }); } getmapdata(2); });
里面最重要的就是从后台获取到的数据是通过传参的形式放到echarts里的。
当时我做的时候未通过传参的形式,在echarts里获取到的数据始终是空的。
上一篇: jsp+ajax实现无刷新上传文件的方法
下一篇: 网络营销推广如何利用关键词推广