8.8k star,最炫酷、最美观的可视化大屏模板,功能很全面!

戳上方蓝字“极客之家”关注我!

今天给大家介绍一款基于 vue、datav、Echart 框架的大数据可视化(大屏展示)模板,提供数据动态刷新渲染、屏幕适应、内部图表自由替换、Mixins注入等功能。

项目描述

一个基于 Vue、Datav、Echart 框架的 ” 数据大屏项目 “,通过 Vue 组件实现数据动态刷新渲染,内部图表可实现自由替换。部分图表使用 DataV 自带组件,可进行更改。

项目环境:

Vue-cli-3.0、DataV-2.7.3、Echarts-4.6.0(如果5.x版本有问题,请切换到4.x版本)、Webpack-4.0、Npm-6.13、Node-v12.16。

主要文件介绍

8.8k star,最炫酷、最美观的可视化大屏模板,功能很全面!

使用介绍

启动项目

需要提前安装好 nodejs 与 yarn,下载项目后在项目主目录下运行 yarn 拉取依赖包。安装完依赖包之后然后使用 vue-cli 或者直接使用命令npm run serve,就可以启动项目,启动项目后需要手动全屏(按 F11)。如果编译项目的时候提示没有 DataV 框架的依赖,输入 npm install @jiaminghi/data-view 或者 yarn add @jiaminghi/data-view 进行手动安装。

封装组件渲染图表

所有的 ECharts 图表都是基于 common/echart/index.vue 封装组件创建的,已经对数据和屏幕改动进行了监听,能够动态渲染图表数据和大小。在监听窗口小大的模块,使用了防抖函数来控制更新频率,节约浏览器性能。

项目配置了默认的 ECharts 图表样式,文件地址:common/echart/theme.json

封装的渲染图表组件支持传入以下参数,可根据业务需求自行添加/删除。

8.8k star,最炫酷、最美观的可视化大屏模板,功能很全面!

动态渲染图表

动态渲染图表案例为 components 目录下各个图表组件,index 文件负责数据获取和处理,chart 文件负责监听和数据渲染。

chart 文件的主要逻辑为:

<template>
  <div>
    <Echart :options="options" id="id" height="height" width="width" ></Echart>
  </div>
</template>

<script>
  // 引入封装组件
import Echart from '@/common/echart'
export default {
  // 定义配置数据
  data(){ return { options: {}}},
  // 声明组件
  components: { Echart},
  // 接收数据
  props: {
    cdata: {
      typeObject,
      default() => ({})
    },
  },
  // 进行监听,也可以使用 computed 计算属性实现此功能
  watch: {
    cdata: {
      handler (newData) {
        this.options ={
          // 这里编写 ECharts 配置
        }
      },
      // 立即监听
      immediatetrue,
      // 深度监听
      deeptrue
    }
  }
};
</script>

复用图表组件

复用图表组件案例为中间部分的 任务通过率与任务达标率 模块,两个图表类似,区别在于颜色和主要渲染数据。只需要传入对应的唯一 id 和样式,然后在复用的组件 components/echart/center/centerChartRate 里进行接收并在对应位置赋值即可。

如:在调用处 views/center.vue 里去定义好数据并传入组件

//组件调用
<span>今日任务通过率</span>
<centerChart :id="rate[0].id" :tips="rate[0].tips" :colorObj="rate[0].colorData" /
>

<span>今日任务达标率</span>
<centerChart :id="rate[1].id" :tips="rate[1].tips" :colorObj="rate[1].colorData" />

...
import centerChart from "@/components/echart/center/centerChartRate";

data() {
  return {
    rate: [
      {
        id"centerRate1",
        tips60,
        ...
      },
      {
        id"centerRate2",
        tips40,
        colorData: {
          ...
        }
      }
    ]
  }
}

相关案例截图

以下案例基于此项目二次开发

支持地图下钻:

https://gitee.com/memeda520/IofTV-Screen

8.8k star,最炫酷、最美观的可视化大屏模板,功能很全面!

重写结构,支持响应式布局:

https://gitee.com/BigCatHome/koi-screen

8.8k star,最炫酷、最美观的可视化大屏模板,功能很全面!

开源地址

https://gitee.com/MTrun/big-screen-vue-datav

后端专属技术群
构建高质量的技术交流社群,欢迎从事编程开发、技术招聘HR进群,也欢迎大家分享自己公司的内推信息,相互帮助,一起进步!
文明发言,以交流技术职位内推行业探讨为主

广告人士勿入,切勿轻信私聊,防止被骗

8.8k star,最炫酷、最美观的可视化大屏模板,功能很全面!

加我好友,拉你进群

8.8k star,最炫酷、最美观的可视化大屏模板,功能很全面!

原文始发于微信公众号(极客之家):8.8k star,最炫酷、最美观的可视化大屏模板,功能很全面!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/292491.html

(0)
码上实战的头像码上实战

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!