大数据应用开发——数据可视化

前言

大数据应用开发------实时数据采集

大数据应用开发------实时数据处理

Flink完成Kafka中的数据消费,将数据分发至Kafka的dwd层中

并在HBase中进行备份

目录

题目

创建Vue项目

引用echarts,并展示柱状图

展示折线图

展示饼图

展示玫瑰图


题目

按照任务书要求编写前端代码,调用后台数据接口,使用Vue.js、ECharts完成数据可视化

创建Vue项目
复制代码
# 以下是一个使用Vue.js 3.0和ECharts 5.1编写的简单示例。这个示例展示了如何在Vue组件中集成ECharts并绘制一个简单的折线图。
# 首先,确保你已经安装了Vue CLI和必要的依赖。你可以使用以下命令来创建一个新的Vue项目(如果还没有的话):
npm install -g @vue/cli  
vue create 项目名  (管理员运行)
cd 项目名
# 然后,安装ECharts:
npm install echarts --save
# 运行:
npm run serve

将模板的HelloWorld.vue删减

复制代码
<template>
</template>

<script>
export default {
  name: 'HelloWorld',
  data(){
    return{
      msg:HelloWorld
    }
  },
  mounted(){
  },
  methods:{
  }
}
</script>

<style scoped>
</style>

请求数据,并打印在控制台上

复制代码
<template>
</template>

<script>
export default {
  name: 'HelloWorld',
  data(){
    return{
    }
  },
  mounted(){
    this.fetchData();
  },
  methods:{
    fetchData(){
      return fetch('https://mock.mengxuegu.com/mock/63bbc9160743af0df9523683/GZOld720/DSY',{
        method: "POST",
        body:JSON.stringify({
          "startTime":"2021-01-01 00:00:00",
          "endTime":"2021-12-31 00:00:00"
        }),
        headers:{  //请求头信息
               'Content-Type':'application/json' 
        }
      })
        .then(response=>response.json())
        .then(data=>{
          const renData = data.list.data;
          console.log(renData);
        })
        .catch(err=>{
          console.log(err)
        })
    }
  }
}
</script>

<style scoped>
</style>
引用echarts,并展示柱状图
复制代码
<template>
  <div id="mychart" class="chart"></div>
</template>

<script>
import * as echart from 'echarts'
export default {
  name: 'HelloWorld',
  data(){
    return{
    }
  },
  mounted(){
    this.fetchData();
  },
  methods:{
    fetchData(){
      return fetch('https://mock.mengxuegu.com/mock/63bbc9160743af0df9523683/GZOld720/DSY',{
        method: "POST",
        body:JSON.stringify({
          "startTime":"2021-01-01 00:00:00",
          "endTime":"2021-12-31 00:00:00"
        }),
        headers:{  //请求头信息
               'Content-Type':'application/json' 
        }
      })
        .then(response=>response.json())
        .then(data=>{
          const renData = data.list.data;
          console.log(renData);

          renData.slice(0,5);

          const option = {
          title:{
            text:"标题"
          },
          xAxis:{
            data:renData.map(i=>i.nationName)
          },
          legend:{
          },
          yAxis:{},
          series:[
            {
              type:"bar",
              data:renData.map(i=>i.totalConsumption),
              name:"消费额"
            }
          ]
        };
        const mychart = echart.init(document.getElementById("mychart"));
        mychart.setOption(option);
        })
        .catch(err=>{
          console.log(err)
        })
    }
  }
}
</script>

<style scoped>
.chart{
  float: left;
  width: 1000px;
  height: 400px;
}
</style>
展示折线图
复制代码
<template>
  <div id="mychart" class="chart"></div>
</template>

<script>
import * as echart from 'echarts'
export default {
  name: 'HelloWorld',
  data(){
    return{
    }
  },
  mounted(){
    this.fetchData();
  },
  methods:{
    fetchData(){
      return fetch('https://mock.mengxuegu.com/mock/63bbc9160743af0df9523683/GZOld720/DSY',{
        method: "POST",
        body:JSON.stringify({
          "startTime":"2021-01-01 00:00:00",
          "endTime":"2021-12-31 00:00:00"
        }),
        headers:{  //请求头信息
               'Content-Type':'application/json' 
        }
      })
        .then(response=>response.json())
        .then(data=>{
          const renData = data.list.data;
          console.log(renData);

          renData.slice(0,5);

          const option = {
          title:{
            text:"标题"
          },
          xAxis:{
            data:renData.map(i=>i.nationName)
          },
          legend:{
          },
          yAxis:{},
          series:[
            {
              type:"line",
              data:renData.map(i=>i.totalConsumption),
              name:"消费额"
            }
          ]
        };
        const mychart = echart.init(document.getElementById("mychart"));
        mychart.setOption(option);
        })
        .catch(err=>{
          console.log(err)
        })
    }
  }
}
</script>

<style scoped>
.chart{
  float: left;
  width: 1000px;
  height: 400px;
}
</style>
展示饼图
复制代码
<template>
  <div id="mychart" class="chart"></div>
</template>

<script>
import * as echart from 'echarts'
export default {
  name: 'HelloWorld',
  data(){
    return{
    }
  },
  mounted(){
    this.fetchData();
  },
  methods:{
    fetchData(){
      return fetch('https://mock.mengxuegu.com/mock/63bbc9160743af0df9523683/GZOld720/DSY',{
        method: "POST",
        body:JSON.stringify({
          "startTime":"2021-01-01 00:00:00",
          "endTime":"2021-12-31 00:00:00"
        }),
        headers:{  //请求头信息
               'Content-Type':'application/json' 
        }
      })
        .then(response=>response.json())
        .then(data=>{
          const renData = data.list.data;
          console.log(renData);

          renData.slice(0,5);

          const option = {
          title:{
            text:"标题"
          },
          legend:{},
          series:[
            {
              type:"pie",
              data:renData.map(i=>({
                name: i.nationName,
                value: i.totalConsumption
              }))
            }
          ]
        };
        const mychart = echart.init(document.getElementById("mychart"));
        mychart.setOption(option);
        })
        .catch(err=>{
          console.log(err)
        })
    }
  }
}
</script>

<style scoped>
.chart{
  float: left;
  width: 1000px;
  height: 400px;
}
</style>
展示玫瑰图
复制代码
<template>
  <div id="mychart" class="chart"></div>
</template>

<script>
import * as echart from 'echarts'
export default {
  name: 'HelloWorld',
  data(){
    return{
    }
  },
  mounted(){
    this.fetchData();
  },
  methods:{
    fetchData(){
      return fetch('https://mock.mengxuegu.com/mock/63bbc9160743af0df9523683/GZOld720/DSY',{
        method: "POST",
        body:JSON.stringify({
          "startTime":"2021-01-01 00:00:00",
          "endTime":"2021-12-31 00:00:00"
        }),
        headers:{  //请求头信息
               'Content-Type':'application/json' 
        }
      })
        .then(response=>response.json())
        .then(data=>{
          const renData = data.list.data;
          console.log(renData);

          renData.slice(0,5);

          const option = {
          title:{
            text:"标题"
          },
          legend:{},
          series:[
            {
              type:"pie",
              radius: [60, 110],
              center: ["40%", 200],
              roseType: "radius",
              data:renData.map(i=>({
                name: i.nationName,
                value: i.totalConsumption
              }))
            }
          ]
        };
        const mychart = echart.init(document.getElementById("mychart"));
        mychart.setOption(option);
        })
        .catch(err=>{
          console.log(err)
        })
    }
  }
}
</script>

<style scoped>
.chart{
  float: left;
  width: 1000px;
  height: 400px;
}
</style>
相关推荐
JieE2121 小时前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 小时前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
kyriewen5 小时前
我用 AI 一周写完了整个项目,上线第一天就崩了——这是我踩过最贵的 5 个坑
前端·javascript·ai编程
Larcher6 小时前
AI Loop:让AI像人一样自主完成任务的核心机制
javascript·人工智能·设计模式
默_笙6 小时前
🃏 JS 只有 8 种数据类型,但我花了 2 天才搞懂 null 和 undefined 的区别
javascript
jump_jump7 小时前
流式 HTML:从 htmx 片段装配到浏览器原生增量渲染
javascript·性能优化·前端工程化
swipe8 小时前
正则表达式入门到进阶:从表单校验到手写模板引擎
前端·javascript·面试
kyriewen9 小时前
前端错误监控最全指南:捕获 JS 异常、Promise 拒绝、资源加载失败,附上报代码
前端·javascript·监控
大家的林语冰9 小时前
ESLint 近期动态大全,新版本正式发布,antfu 大佬推荐的插件也更新了!
前端·javascript·前端工程化
胡志辉10 小时前
深入浅出 call、apply、bind
前端·javascript·后端