博客
关于我
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/

    你可能感兴趣的文章
    npm install 报错 fatal: unable to connect to github.com 的解决方法
    查看>>
    npm install 报错 no such file or directory 的解决方法
    查看>>
    npm install 权限问题
    查看>>
    npm install报错,证书验证失败unable to get local issuer certificate
    查看>>
    npm install无法生成node_modules的解决方法
    查看>>
    npm install的--save和--save-dev使用说明
    查看>>
    npm node pm2相关问题
    查看>>
    npm run build 失败Compiler server unexpectedly exited with code: null and signal: SIGBUS
    查看>>
    npm run build报Cannot find module错误的解决方法
    查看>>
    npm run build部署到云服务器中的Nginx(图文配置)
    查看>>
    npm run dev 和npm dev、npm run start和npm start、npm run serve和npm serve等的区别
    查看>>
    npm run dev 报错PS ‘vite‘ 不是内部或外部命令,也不是可运行的程序或批处理文件。
    查看>>
    npm scripts 使用指南
    查看>>
    npm should be run outside of the node repl, in your normal shell
    查看>>
    npm start运行了什么
    查看>>
    npm WARN deprecated core-js@2.6.12 core-js@<3.3 is no longer maintained and not recommended for usa
    查看>>
    npm 下载依赖慢的解决方案(亲测有效)
    查看>>
    npm 安装依赖过程中报错:Error: Can‘t find Python executable “python“, you can set the PYTHON env variable
    查看>>
    npm.taobao.org 淘宝 npm 镜像证书过期?这样解决!
    查看>>
    npm—小记
    查看>>