基于vue3 的 Echarts图表展示(任务一:用柱状图展示消费额最高的省份)(操作全流程)(图文版)

目录

前言:

操作要求:

操作流程:

一.创建vue项目

1.在vscode上创建vue脚手架工程

二.配置运行环境

[2.配置axios(用于访问接口) 和引入echarts包](#2.配置axios(用于访问接口) 和引入echarts包)

3.引入需要用到的js包

三.开始实践做题(最后附有完整代码)

1.获取接口数据

2.数据处理

3.echarts图表展示

4.最终效果图

4.完整参考代码


前言:

这篇是一个基于vue3上的echarts图表展示文章,无论你有没有基础 ,只要看这篇文章你都可以学会!加油哦~

操作要求:

++++编写Vue工程代码,根据接口,用柱状图展示2++++ ++++020年++++ ++++消费额最高的5个省份,同时将用于图表展示的数据结构在浏览器的console中进行打印输出,将图表可视化结果和浏览器console打印结果分别截图并粘贴至++++ ++++对应报告中++++。

操作流程:

一.创建vue项目

1.在vscode上创建vue脚手架工程

1.1 由node去下拉vuecli脚手架(未安装node的请查看文章:安装npm

​​

1.2 创建vue项目命令:vue create test3

​​ ​​

然后用vscode打开该vue工程

二.配置运行环境

2.配置axios(用于访问接口) 和引入echarts包

2.1 首先先打开vscode终端(快捷键Ctrl+`),引入axios包和Echarts包

如果你没有这两个包,可以私信我领取哦!

2.2 配置代理服务器

在vuecli的工程脚手架项目中找到vue.config.js文件,有则打开,无则新

​​

2.3 在vue.config.js中 配置代理服务器,代码如下:(注意配置的ip地址)

javascript 复制代码
module.exports = {
    
    devServer: {
      proxy: 'http://192.168.23.xx:xxxx'  //配置代理服务器(域名和端口为被请求方的)
    }
  }

注意:配置完后必须重新启动vuecli脚手架服务才会生效!!!

3.引入需要用到的js包

3.1.新建一个vue组件,引入axios和echarts

三.开始实践做题(最后附有完整代码)

题目分析: 根据最上方题目要求,可以分析出,主要的代码步骤是:

1.获取接口数据

2.数据处理

3.echarts图表展示

1.获取接口数据

此处涉及到异步变同步问题,可以参考这篇文章:异步->同步接口请求

javascript 复制代码
// async 和 await 让异步变同步
async  function getdata(){
        // 设置带参请求
          let proms={
            "startTime":"2020-01-01 00:00:00",
            "endTime":"2020-12-30 00:00:00"
                }
         const alldata = await    axios.post("http://localhost:8080/dataVisualization/**",proms).then((request)=>{
          return request.data.data
           },(error)=>
           {
                console.log(error)
           })
           culdata(alldata)
        }

2.数据处理

javascript 复制代码
  // 处理数据
        function culdata(data){
            let map = new Map()
            for(let i in data){
                let finalTotalAmount = data[i].finalTotalAmount   //拿到金额
                let provinceName = data[i].provinceName  // 拿到省份

                if(map.has(provinceName)){
                    map.set(provinceName,map.get(provinceName)+finalTotalAmount)
                }else{
                    map.set(provinceName,finalTotalAmount)
                }
            }

        // 类型转换并排序取前五
      let newdata =    Array.from(map).sort((a,b)=>b[1]-a[1]).slice(0,5)
       console.log(newdata) 
        
      let    xdataa =[]
      let   ydataa =[]
    //   分别取出数组中的数据
       for(let [k,v] of newdata){
        xdataa.push(k)
        ydataa.push(v)
       }
      xdata = xdataa
      ydata = ydataa
    //   调用绘图方法
       initEcharts()
        }

3.echarts图表展示

javascript 复制代码
 function initEcharts(){
            // 初始化dom元素
         let barone = echarts.init(document.getElementById("one"))
         barone.setOption({
            title:{
                text:"柱状图展示2020年消费前5省"
            },
            // 设置x轴
            xAxis:{
                type:"category",
                data: xdata
            },
            // 设置y轴
            yAxis:{
                type:"value"
            },
            // 设置配置项
            series:{
                name:"one",
                type:"bar",
                data:ydata
            }
         })
}

4.最终效果图

4.完整参考代码

javascript 复制代码
<template>
  <div id="one" class="root">123</div>
</template>

<script>
import { onMounted } from 'vue'
import axios from "../assets/axios"
import echarts from "../assets/echarts"
export default {

    setup(){
        let xdata = ""
        let ydata = ""

        // 获取数据
       async  function getdata(){
        // 设置带参请求
          let proms={
            "startTime":"2020-01-01 00:00:00",
            "endTime":"2020-12-30 00:00:00"
                }
         const alldata = await    axios.post("http://localhost:8080/dataVisualization/selectOrderInfo",proms).then((request)=>{
          return request.data.data
           },(error)=>
           {
                console.log(error)
           })
           culdata(alldata)
        }
        
	// finalTotalAmount :总金额
	// provinceName :省名称
	
        // 处理数据
        function culdata(data){
            let map = new Map()
            for(let i in data){
                let finalTotalAmount = data[i].finalTotalAmount   //拿到金额
                let provinceName = data[i].provinceName  // 拿到省份

                if(map.has(provinceName)){
                    map.set(provinceName,map.get(provinceName)+finalTotalAmount)
                }else{
                    map.set(provinceName,finalTotalAmount)
                }
            }

        // 类型转换并排序取前五
      let newdata =    Array.from(map).sort((a,b)=>b[1]-a[1]).slice(0,5)
       console.log(newdata) 
        
      let    xdataa =[]
      let   ydataa =[]
    //   分别取出数组中的数据
       for(let [k,v] of newdata){
        xdataa.push(k)
        ydataa.push(v)
       }
      xdata = xdataa
      ydata = ydataa
    //   调用绘图方法
       initEcharts()
        }

// 绘图
        function initEcharts(){
            // 初始化dom元素
         let barone = echarts.init(document.getElementById("one"))
         barone.setOption({
            title:{
                text:"柱状图展示2020年消费前5省"
            },
            // 设置x轴
            xAxis:{
                type:"category",
                data: xdata
            },
            // 设置y轴
            yAxis:{
                type:"value"
            },
            // 设置配置项
            series:{
                name:"one",
                type:"bar",
                data:ydata
            }
         })
        console.log(ydata)
        console.log(xdata)
        }

        onMounted(()=>{
            getdata()
        })
    }
}
</script>

<style>
.root {
  width: 700px;
  height: 400px;
  border: 1px solid red;
  float: right;
}
</style>
相关推荐
码爸24 分钟前
flink doris批量sink
java·前端·flink
深情废杨杨25 分钟前
前端vue-父传子
前端·javascript·vue.js
工业互联网专业1 小时前
毕业设计选题:基于springboot+vue+uniapp的驾校报名小程序
vue.js·spring boot·小程序·uni-app·毕业设计·源码·课程设计
J不A秃V头A1 小时前
Vue3:编写一个插件(进阶)
前端·vue.js
司篂篂2 小时前
axios二次封装
前端·javascript·vue.js
姚*鸿的博客2 小时前
pinia在vue3中的使用
前端·javascript·vue.js
宇文仲竹3 小时前
edge 插件 iframe 读取
前端·edge
Kika写代码3 小时前
【基于轻量型架构的WEB开发】【章节作业】
前端·oracle·架构
天下无贼!4 小时前
2024年最新版Vue3学习笔记
前端·vue.js·笔记·学习·vue
Jiaberrr4 小时前
JS实现树形结构数据中特定节点及其子节点显示属性设置的技巧(可用于树形节点过滤筛选)
前端·javascript·tree·树形·过滤筛选