Django echarts初试随笔

Django项目的配置文件APP配置

INSTALLED_APPS = [
    ‘django.contrib.admin‘,         # 管理员站点
    ‘django.contrib.auth‘,          # 认证授权系统
    ‘django.contrib.contenttypes‘,  # 内容类型框架
    ‘django.contrib.sessions‘,      # 会话框架
    ‘django.contrib.messages‘,      # 消息框架
    ‘django.contrib.staticfiles‘,   # 管理静态文件的框架
    ‘myapp‘,
    ‘django_echarts‘,               # 注册Django rest framework
    ‘rest_framework‘,               # 在这里需要注册Django rest framework
]

Django项目的URL配置

from django.contrib import admin
from django.urls import include, path

urlpatterns = [
    path(‘admin/‘, admin.site.urls),
    path(‘‘, include(‘myapp.urls‘))
]

APP路由配置

from django.urls import path
from . import views

urlpatterns = [
    path(‘‘, views.index, name=‘index‘),
    path(‘show/‘, views.ChartView.as_view(), name=‘show‘)
]

APP视图代码

from django.shortcuts import HttpResponse
from django.shortcuts import render

from pyecharts.charts import Bar
from pyecharts import options

from rest_framework.views import APIView

from random import randrange

import json
import os

def index(request):
    return render(request, ‘main.html‘)

def response_as_json(data):
    json_str = json.dumps(data)
    response = HttpResponse(
        json_str,
        content_type=‘application/json‘
    )
    response[‘Access-Control-Allow-Region‘] = ‘*‘

    return response

def json_response(data, code=200):
    data = {
        ‘code‘: code,
        ‘msg‘: ‘success‘,
        ‘data‘: data,
    }
    return response_as_json(data)

def json_error(error_string=‘error‘, code=500, **kwargs):
    data = {
        ‘code‘: code,
        ‘msg‘: error_string,
        ‘data‘: {}
    }
    data.update(kwargs)
    return response_as_json(data)

JsonResponse = json_response
JsonError = json_error

def bar_base() -> Bar:
    bar = (
        Bar()
        .add_xaxis(["衬衫", "羊毛衫", "雪纺衫", "裤子", "高跟鞋", "袜子"])
        .add_yaxis(‘商家A‘, [randrange(0, 100) for _ in range(6)])
        .set_global_opts(title_opts=options.TitleOpts(title=‘这是标题‘, subtitle=‘这是副标题‘))
        .dump_options_with_quotes()
    )
    return bar

class ChartView(APIView):
    def get(self, request, *args, **kwargs):
        return JsonResponse(json.loads(bar_base()))

模板页实现

<!DOCTYPE html>
<html lang="en" xmlns="http://www.w3.org/1999/html">
<head>
    <meta charset="UTF-8">
    {% load static %}
    <link rel="stylesheet" href="{% static ‘bootstrap-3.3.7-dist/css/bootstrap.min.css‘ %}" type="text/css"/>
    <script src="{% static ‘echarts-4.5.0/echarts.common.min.js‘ %}"></script>
    <script src="{% static ‘jquery/jquery.min.js‘ %}"></script>
    <script src="{% static ‘bootstrap-3.3.7-dist/js/bootstrap.min.js‘ %}"></script>
    <title>Index</title>
</head>
<body>
 <div class="container">
        {% block content %}
        {% endblock %}
    </div>
</body>
</html>
刷新界面实现
{% extends ‘index.html‘ %}
{% block content %}
    <div id="bar" style="width: 800px; height: 600px"></div>
    {{ data | safe }}
    <script>
        var myChart = echarts.init(document.getElementById(‘bar‘), ‘white‘, {renderer: ‘cavnvas‘});

        $(
            function () {
                fetchData();
                window.setInterval(fetchData, 2000)
            }
        );

        function fetchData() {
            $.ajax({
                type: ‘GET‘,
                url: ‘/show/‘,
                dataType: ‘json‘,
                success: function (result) {
                    myChart.setOption(result.data)
                },
                error: function (result) {
                    console.log(result)
                }
            })
        }
    </script>
{% endblock %}

原文地址:https://www.cnblogs.com/kris-wang/p/12208193.html

时间: 2024-11-22 21:14:40

Django echarts初试随笔的相关文章

搜索引擎--范例:django之初试牛刀

这学期学了一门课<信息检索>,也就是传说中的搜索引擎 大作业自然而然的让我们自己做一个小型的搜索引擎.于是乎,我们本次的主题就诞生了 我也是边学边用,下面和大家一起分享我在这个过程中学到的东西,说的不对的请大家指正 这是我的成果搜索引擎--范例,大家可以点进去看看,点此下载所有文件盒源代码 按照流程,下面我给大家分享的依次是: 1:SAE创建新应用,SVN管理代码 2:新浪微博API获取最近的微博 3:中文分词算法的实现 4:谈谈django--mysql数据库的一些常用命令 搜索引擎--范例

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使用随笔(1)-Echarts中markPoint的使用(静态、动态)-effect

先看一段关于初始化Echart   js的使用 myChart = echarts.init(document.getElementById('mainChart')); var option; option = { title : { text: '全国主要城市空气质量(pm2.5)', subtext: 'data from PM25.in', sublink: 'http://www.pm25.in', x:'center' }, tooltip : { trigger: 'item' }

Echarts使用随笔(2)-Echarts中mapType and data

本文出处:http://blog.csdn.net/chenxiaodan_danny/article/details/39081071 series : [ { name: 'iphone3', type: 'map', mapType: '杭州市', roam: true, itemStyle:{ normal:{label:{show:true}}, emphasis:{label:{show:true}} }, data:[ //{name: '杭州',value: Math.round

Ubuntu Nginx uwsgi django 初试

/************************************************************************************** * Ubuntu Nginx uwsgi django 初试 * 说明: * 最近打算通过Python搭建一个数据收集的网站,先做一个搭建测试. * * 2016-8-5 深圳 南山平山村 曾剑锋 ***************************************************************

Python+Django+js+echarts引入本地js文件的操作方法

1. 选择正确的echarts.js,开发版选择echarts.baidu.com上的源码版,避免出现问题 2. 在项目主目录中新建static文件夹,里面建立js.css.images文件夹 3. 在settings文件中新增如下代码配置: STATIC_URL = '/static/' STATIC_ROOT = os.path.join(BASE_DIR, 'static') STATICFILES_DIRS = ( ('css', os.path.join(STATIC_ROOT, 'c

七日Python之路--第三天(之初试Django 2-2)

接上文.前面(1)(2)部分已经实现浏览器访问工程项目,并且能后台管理新创建的app. (二)第一个Django的app (3)教你开始写Django1.6的第1个app 前面已经完成了model(M)的设置.剩下的只有view(V)和urls(C)了.Django的视图部分,由views.py 和 templates完成. 在polls中,我们将创建4个视图: "index" 列表页 – 显示最新投票. "detail" 投票页 – 显示一个投票的问题, 以及用户

django 初试

/************************************************************************************** * django 初试 * 说明: * 昨天打搭了dgango的服务器,今天学一下怎么来输出一个hello world出来. * * 2016-8-6 深圳 南山平山村 曾剑锋 *************************************************************************

百度图表数据插件echarts的初试

身为一个小前端,当得知需要在页面根据后台数据绘制统计数据的图表时,一筹莫展,幸好遇见了百度的ECharts插件,这款插件容易入手: 一下为初试: prepare.js//稍微封装,易于复用 /* *function getJson() *为获取后台的数据json *json.data为报表数据对应横轴的值 *json.name为报表横坐标的名称 */ function getJson(){ var jsondata = {}; jsondata.legendName = []; //图表的表面