初探vue+nodejs+echarts展示图表

   2023-02-09 学习力0
核心提示:初探vue+nodejs+echarts展示图表nodejs服务server.js代码: 1 var express = require('express') 23 var app = express() 45 var fs = require('fs') 67 var mysql = require('mysql') 89 var cors = require('cors')10 11 // 设置跨域访问12 app.all

初探vue+nodejs+echarts展示图表

nodejs服务server.js代码:

 1 var express = require('express')
 2 
 3 var app = express()
 4 
 5 var fs = require('fs')
 6 
 7 var mysql = require('mysql')
 8 
 9 var cors = require('cors')
10 
11 // 设置跨域访问
12 app.all('*', function (req, res, next) {
13   res.header('Access-Control-Allow-Origin', '*')
14   res.header('Access-Control-Allow-Headers', 'X-Requested-With')
15   res.header('Access-Control-Allow-Methods', 'PUT,POST,GET,DELETE,OPTIONS')
16   res.header('X-Powered-By', ' 3.2.1')
17   res.header('Content-Type', 'application/json;charset=utf-8')
18   next()
19 })
20 
21 app.use(
22   cors({
23     origin: ['http://localhost:3000'],
24     methods: ['get', 'post'],
25     allowedHeaders: ['Content-Type', 'Authorization']
26   })
27 )
28 
29 const db = mysql.createConnection({
30   host: 'localhost',
31   user: 'root',
32   password: '******',
33   port: '3306',
34   database: 'tables'
35 })
36 
37 db.connect(err => {
38   if (err) throw err
39   console.log('连接成功')
40 })
41 
42 app.get('/schoolpm', (req, res) => {
43   let sql = 'SELECT school_name,qk_count FROM school_all ORDER BY qk_count desc LIMIT 5'
44   db.query(sql, (err, result) => {
45     if (err) {
46       console.log(err)
47     } else {
48       res.json(result)
49     }
50   })
51 })
52 
53 var server = app.listen(3000, function () {
54   var host = server.address().address
55   var port = server.address().port
56   console.log(host, port)
57 })

 

mysql表数据:

初探vue+nodejs+echarts展示图表

 

 

运行node服务测试接口:

初探vue+nodejs+echarts展示图表

 

 

html代码:

  1 <!DOCTYPE html>
  2 <html lang="en">
  3   <head>
  4     <meta charset="UTF-8" />
  5     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  6     <title>123</title>
  7     <script src="https://cdn.jsdelivr.net/npm/vue"></script>
  8     <script src="node_modules/axios/dist/axios.min.js"></script>
  9     <script src="js/echarts.min.js"></script>
 10     <script src="js/main.js"></script>
 11     <style>
 12       .topSchool {
 13         background-color: rgba(0, 0, 59, 1);
 14         color: beige;
 15       }
 16       #topSchool-pie {
 17         height: 400px;
 18         width: 400px;
 19       }
 20     </style>
 21   </head>
 22   <body>
 23     <div id="schPm">
 24       <div class="topSchool">
 25         <h3>高校排名</h3>
 26         <div id="topSchool-pie"></div>
 27       </div>
 28     </div>
 29 
 30     <script>
 31       var highSchoolPM = new Vue({
 32         el: "#schPm",
 33         data: {
 34           pmList: []
 35         },
 36         created() {
 37           this.getData();
 38         },
 39         methods: {
 40           getData() {
 41             axios
 42               .get(`${api}/schoolpm`)
 43               .then(res => {
 44                 var obj = res.data;
 45                 // school_name替换为name,qk_count替换为value
 46                 obj.forEach(e => {
 47                   e.name = e.school_name;
 48                   e.value = e.qk_count;
 49                   delete e.qk_count;
 50                   delete e.school_name;
 51                 });
 52                 console.log(obj);
 53 
 54                 this.pmList = obj;
 55                 this.$nextTick(() => {
 56                   this.draw();
 57                 });
 58               })
 59               .catch(err => {
 60                 console.log(err);
 61               });
 62           },
 63           draw() {
 64             var _this = this;
 65             var myPM = echarts.init(document.getElementById("topSchool-pie"));
 66             var optionPM = {
 67               title: {
 68                 text: "前五名排名",
 69                 left: "center",
 70                 top: 20,
 71                 textStyle: {
 72                   color: "#ccc"
 73                 }
 74               },
 75 
 76               tooltip: {
 77                 trigger: "item",
 78                 formatter: "{a} <br/>{b} : {c} ({d}%)"
 79               },
 80 
 81               color: ["#0072ff", "#843bff", "#e6772d", "#0033ff", "#48dee6"],
 82 
 83               visualMap: {
 84                 show: false,
 85                 min: 80,
 86                 max: 600,
 87                 inRange: {
 88                   // colorLightness: [0, 1]
 89                 }
 90               },
 91               series: [
 92                 {
 93                   name: "高校期刊资源",
 94                   type: "pie",
 95                   radius: "55%",
 96                   center: ["50%", "50%"],
 97                   data: this.pmList.sort(function(a, b) {
 98                     return a.value - b.value;
 99                   }),
100                   roseType: "radius",
101                   labelLine: {
102                     smooth: 0.2,
103                     length: 10,
104                     length2: 20
105                   },
106                   itemStyle: {
107                     // color: '#c23531',
108                     shadowBlur: 200,
109                     shadowColor: "rgba(0, 0, 0, 0.5)"
110                   },
111 
112                   animationType: "scale",
113                   animationEasing: "elasticOut",
114                   animationDelay: function(idx) {
115                     return Math.random() * 200;
116                   }
117                 }
118               ]
119             };
120             myPM.setOption(optionPM);
121           }
122         }
123       });
124     </script>
125   </body>
126 </html>

 

效果图:

初探vue+nodejs+echarts展示图表

 

 
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • 打造自己的 nodejs 静态文件服务器(帖子内容,
    用NodeJS打造你的静态文件服务器在《The Node Beginner Book》的中文版(http://nodebeginner.org/index-zh-cn.html)发布之后,获得国内的好评。也有同学觉得这本书略薄,没有包含进阶式的例子。@otakustay同学说:“确实,我的想法是在这之上补一个简单的MV
    02-10
  • NodeJS无所不能:细数10个令人惊讶的NodeJS开源
    在几年的时间里,NodeJS逐渐发展成一个成熟的开发平台,吸引了许多开发者。有许多大型高流量网站都采用NodeJS进行开发,像PayPal,此外,开发人员还可以使用它来开发一些快速移动Web框架。  除了Web应用外,NodeJS也被应用在许多方面,本文盘点了NodeJS在其
    02-10
  • Linux环境下的Nodejs linux安装基本环境
    最近在学习Node.js,在window下总是觉得不那么爽快。最简单而且环保的方法是在虚拟机中安装一个Linux。 { 1.Linux:家中的Linux为Centos。 2.VirtuallyBox: 开启2块网卡。第一个选Host-Only目的是为了让虚拟机通上网。第二块选Bridge Adapter,这是为了
    02-09
  • nodejs package.json说明
    {"name": "test", //项目名称(必须),由小写英文字母、数字和下划线,不能含空格"version": "1.0.0", //项目版本(必须)"description": "This is for study gulp project !", //项目描述(必须)"homepage": "", //项目主页url " key
    02-09
  • 017 nodejs取参四种方法req.body,req.params,re
    摘要: nodejs取参四种方法req.body,req.params,req.param,req.body 获取请求很中的参数是每个web后台处理的必经之路,nodejs提供了四种方法来实现。获取请求很中的参数是每个web后台处理的必经之路,nodejs的 express框架 提供了四种方法来实现。req.bodyre
    02-09
  • Docker windows下安装并搭建Nodejs的webapp
    Docker windows下安装并搭建Nodejs的webapp
    一、关于Docker什么是Docker?Docker 采用go语言编写,是一个开源的应用容器引擎。让开发者可以快速打包他们的应用以及依赖包到一个封装的可移植的容器Image中,然后发布到任何流行的机器( Linux ,windows,Mac等)上,也可以实现虚拟化。容器是使用完全
    02-09
  • Nodejs+Express+Mysql实现简单用户管理增删改查
    Nodejs+Express+Mysql实现简单用户管理增删改查
     源码地址  https://github.com/king-y/NodeJs/tree/master/user目录结构  mysql.jsvar mysql = require('mysql');var pool = mysql.createPool({host : '127.0.0.1',user : 'root',password : '',database : 's79'});exports.que
    02-09
  • nodejs查看本机hosts文件域名对应ip
    const dns = require('dns')dns.lookup('domainName', function(err, result) {console.log(result)}) related:https://***.com/questions/36689536/how-to-resolve-hostname-to-an-ip-address-in-node-js
    02-09
  • nodejs process.memoryUsage() rss等参数啥含义
    nodejs process.memoryUsage() rss等参数啥含义
    1 前言使用process.memoryUsage() ,然后可以得到一个对象如下:{ rss: 4935680,heapTotal: 1826816,heapUsed: 650472,external: 49879}  然而不知道rss是什么缩写,不知道其含义,网上找了一圈,多数都没说到点上,我这边就补充一下,也作为记录使用。2 
    02-09
  • nodejs工程拷贝后运行报module找不到问题
    工程文件夹通过复制黏贴到另外一个地方,运行后报错 “can`t find module 某某某”,查看原因:输入node 进入控制台,输入console.log(module.paths)查看当前nodejs查找module的路径,如果没有工程里的node_modules,通过module.paths.push加入,检查是否有效
    02-09
点击排行