博客
关于我
echarts异步请求后台数据(flask, express, beego版本)
阅读量:808 次
发布时间:2019-03-25

本文共 3095 字,大约阅读时间需要 10 分钟。

使用ECharts搭建数据可视化案例及前后端搭建( Flask, Express, Beego)

前言

ECharts 是一个强大的可视化 JS 库,功能强大且易于使用。通过本文案例,大家将从头到尾学习如何用 ECharts 实现一个简单的数据可视化页面,并通过 Flask、Express、Beego 三个框架分别搭建后台服务器。


项目结构

项目主要包含以下几个部分:

  • Frontend(前端):用于创建数据可视化页面,包括数据展示和数据请求功能。
  • Backend(后端):通过 Flask、Express、Beego 分别搭建后台 API,提供数据随机生成接口。

  • 前端部分

    前端页面主要包含以下功能:

  • 依赖文件加载:加载 ECharts 和 jQuery 函数文件。
  • 数据请求:通过 AJAX 获取后台生成的数据。
  • 数据展示:使用 ECharts 绘制柱状图,显示各科目成绩。
  • 自动刷新:页面一刷新就会重新获取数据。
  •     
    成绩可视化

    Flask 实现

  • 安装依赖:```bashpip install flask flask-cors
  • 2. 创建 `app.py` 文件:```pythonfrom flask import Flask, jsonifyfrom flask_cors import *import randomapp = Flask(__name__)app.config['JSON_AS_ASCII'] = FalseCORS(app, supports_credentials=True)@app.route('/random')def get_random_data():    subjects = ['Chinese', 'Mathematics', 'English', 'Physics', 'History',                'Politics', 'Geography', 'Chemistry', 'Biology']    data = {s: random.randint(1, 100) for s in subjects}    return jsonify(data)if __name__ == '__main__':    app.run(host='0.0.0.0', port=3000)
    1. 运行:```bashpython app.py
    2. ---#### Express 实现1. 安装依赖:```bashnpm install express
      1. 创建 app.js 文件:
      2. const express = require('express');const app = express();const allowCross = function(req, res, next) {    res.header('Access-Control-Allow-Origin', '*');    next();};app.use(allowCross);function getRandomInt(max) {    return Math.floor(Math.random() * Math.floor(max));}app.get('/random', function(req, res) {    const subjects = ['Chinese', 'Mathematics', 'English', 'Physics', 'History',                      'Politics', 'Geography', 'Chemistry', 'Biology'];    const scores = {};        for (const subject of subjects) {        scores[subject] = getRandomInt(101);    }        res.json(scores);});const server = app.listen(3000, function() {    const port = server.address().port;    console.log('访问地址为 http://127.0.0.1:%s', port);});
        1. 运行:```bashnode app.js
        2. ---#### Beego 实现1. 安装 Go 和 Beego:```bashgo get -u https://github.com/astaxie/beego
          1. 创建 app.go 文件:
          2. package mainimport (    "encoding/json"    "fmt"    "math/rand"    "github.com/astaxie/beego"    "github.com/astaxie/beego/context"    "github.com/astaxie/beego/plugins/cors")func main() {    beego.InsertFilter("*", beego.BeforeRouter, cors.Allow(&cors.Options{        AllowAllOrigins: true,    }))    beego.Get("/random", func(c *context.Context) {        scores := make(map[string]int)        subjects := []string{            "Chinese", "Mathematics", "English", "Physics",             "History", "Politics", "Geography", "Chemistry", "Biology"        }                for _, subject := range subjects {            scores[subject] = rand.Intn(101)        }                data, err := json.MarshalIndent(scores, "", "\t")        if err != nil {            fmt.Printf("错误:%v\n", err)            return        }                c.Output.JSON(data, true, true)    })    beego.Run("localhost:3000")}
            1. 运行:```bashgo run app.go
            2. ---#### 项目效果1. 数据展示:页面加载后自动显示各科目成绩柱状图。2. random 刷新:点击按钮后,数据会重新随机生成并展示。3. 跨域支持:前后端互通无阻。---#### 结语本文通过 ECharts 实现了一个简单的学科成绩可视化页面,并分别使用 Flask、Express、Beego 搭建后台 API。感谢您的阅读,欢迎留言讨论!

    转载地址:http://vfayk.baihongyu.com/

    你可能感兴趣的文章
    Mysql 常见ALTER TABLE操作
    查看>>
    MySQL 常见的 9 种优化方法
    查看>>
    MySQL 常见的开放性问题
    查看>>
    Mysql 常见错误
    查看>>
    mysql 常见问题
    查看>>
    MYSQL 幻读(Phantom Problem)不可重复读
    查看>>
    mysql 往字段后面加字符串
    查看>>
    mysql 快照读 幻读_innodb当前读 与 快照读 and rr级别是否真正避免了幻读
    查看>>
    MySQL 快速创建千万级测试数据
    查看>>
    mysql 快速自增假数据, 新增假数据,mysql自增假数据
    查看>>
    MySql 手动执行主从备份
    查看>>
    Mysql 批量修改四种方式效率对比(一)
    查看>>
    mysql 批量插入
    查看>>
    Mysql 报错 Field 'id' doesn't have a default value
    查看>>
    MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
    查看>>
    Mysql 拼接多个字段作为查询条件查询方法
    查看>>
    mysql 排序id_mysql如何按特定id排序
    查看>>
    Mysql 提示:Communication link failure
    查看>>
    mysql 插入是否成功_PDO mysql:如何知道插入是否成功
    查看>>
    Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
    查看>>