django+echarts+ajax非同步+顯示最佳化--基本例子

來源:互聯網
上載者:User

標籤:ajax   django   echarts   

django+echarts+ajax非同步+顯示最佳化--基本例子

<div   style="height:300px;"id="echarts-line"></div>##定義要顯示的地方<script src="/static/js/echarts.min.js"></script> #載入js<script>    $(function () {        var server_info;        var myChart = echarts.init(document.getElementById(‘echarts-line‘));        var option = {            title: {                text: ‘機櫃總數‘            },            tooltip: {},            legend: {                data:[‘總數‘]            },            xAxis: {                data: {{ name  | safe }}    ##第一次訪問頁面時,先從後端返回一個最新的資料,這樣子就不會需要人們等著更新資料。            },            yAxis: {},            series: [{                name: ‘銷量‘,                type: ‘bar‘,                data: {{ jq | safe }} ##第一次訪問頁面時,先從後端返回一個最新的資料            }]        };        myChart.setOption(option, true);{#        myChart.showLoading();#}   ## echarts 的顯示載入頁面        setInterval( function () {     ##AJAX去擷取資料通過showapi                $.ajax({                    type: ‘GET‘,                    url: ‘/jigui/showapi‘,                    dataType: ‘json‘,                    success: function (json) {                        server_info = eval(json);                    }                });                    option.xAxis.data =  server_info.name;   ##賦值                    option.series[0].data = server_info.jq;{#                    myChart.hideLoading();#}   ## echarts 的隱藏載入頁面                    myChart.setOption(option, true);                }, 2000);  ##每隔2秒 擷取一次,重建值         window.onresize = function () {            myChart.resize();      ##根據頁面大小重新定義圖形大小        };    });</script>



@login_required(login_url="/login.html")def show(request):  ## 展示         第一次訪問返回一個資料             name_id = models.JiguiInfo.objects.filter(id__gt=0)    name = []    jq = []    for i in name_id:        name.append(i.name)        jq.append(i.jq)        ret = {‘name‘: name, ‘jq‘: jq}        return render(request, ‘jigui/show.html‘,{‘name‘:name,‘jq‘:jq})@login_required(login_url="/login.html")def showapi(request):  ## 展示    API返回資料    name_id = models.JiguiInfo.objects.filter(id__gt=0)    name = []    jq = []    for i in name_id:        name.append(i.name)        jq.append(i.jq)        ret={‘name‘:name,‘jq‘:jq}    return  HttpResponse(json.dumps(ret))



本文出自 “何全” 部落格,請務必保留此出處http://hequan.blog.51cto.com/5701886/1954409

django+echarts+ajax非同步+顯示最佳化--基本例子

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.