vue 项目下使用dataV和echarts 开发可视化大屏

本文主要是介绍vue 项目下使用dataV和echarts 开发可视化大屏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

先贴效果图,静态图开不出动态效果。
在这里插入图片描述
首先得安装依赖
“@jiaminghi/data-view”: “^2.10.0”,
“echarts”: “^5.2.1”,
“screenfull”: “^5.2.0”,

首页代码

<template><div :class="figureBG == 1 ? 'figure-page' : 'figure-page'" ref="figure" class="img_bg"><dv-decoration-9 class="loading" v-if="isShowLoading"><dv-digital-flop class="schedule" :config="configLoad" /></dv-decoration-9><dv-full-screen-container><div>&nbsp;</div><template v-if="!isShowLoading"><!-- 第一行 --><!-- <div class="jc-center"><dv-decoration-10 style="width: 33.3%; height: 5px" /><div class="jc-center"><dv-decoration-8:color="color"style="width: 200px; height: 50px"/><div class="title"><span class="title-text">车险人伤第三方机构多维数字化看板</span><dv-decoration-6class="title-bototm":reverse="true":color="['#50e3c2', '#67a1e5']"style="width: 130px; height: 18px"/></div><dv-decoration-8:reverse="true":color="color"style="width: 200px; height: 50px"/></div><dv-decoration-10style="width: 33.3%; height: 5px; transform: rotateY(180deg)"/></div> --><dv-border-box-11 title="大数据展示" class="box_11"><!-- 第二行 --><div class="jc-between"><div class="d-flex" style="width: 40%"><divclass="react-right ml-4"style="width: 625px; text-align: left; background-color: #233556"@click="toBack"><span class="react-before"></span><span class="text">返回上级页面</span></div><divclass="react-right bg-color-blue ml-3"@click="handleScreenfull"><span class="text">全屏展示</span></div></div><dv-decoration-5 style="width:300px;height:40px;" />"<div style="width: 40%" class="d-flex"><divclass="react-left mr-3"style="background-color: #233556"@click="toggleBg"><span class="text fw-b"></span></div><divclass="react-left mr-4"style="width: 625px; background-color: #233556; text-align: right"><span class="react-after"></span><div class="date-row text react-left_qj"><span class="title_qj">数据统计区间:&nbsp;</span><el-date-pickerclass="daterange_qj"v-model="date"type="daterange"align="right"unlink-panelsrange-separator="至"start-placeholder="开始日期"end-placeholder="结束日期":picker-options="pickerOptions"@change="init"></el-date-picker></div></div></div></div><div class="table-flex-box"><Left ref="left" /><Center ref="center" /><Right ref="right" /></div></dv-border-box-11>    </template></dv-full-screen-container></div></template><script>import Vue from 'vue'import dataV from '@jiaminghi/data-view'import * as echarts from 'echarts/core'import { BarChart } from 'echarts/charts'import screenfull from 'screenfull'//   import Left from '@/components/board/Left'import Left from './board/Left'import Center from './board/Center'import Right from './board/Right'Vue.use(dataV)// 注册必须的组件echarts.use([BarChart])export default {data() {let end = new Date()let start = new Date(`2022/01/01`)return {color: ['#568aea', '#020814'], // 第一行的背景色screenfullBut: false, //全屏configLoad: {// 加载数值number: [parseInt(parseInt(Math.random() * 20) + 30)],content: '{nt}%',style: {fontSize: 18,fill: '#3de7c9'}},isShowLoading: true, // 展示加载figureBG: 1, // 背景模式 1图片 0纯色date: [start, end], //选择时间pickerOptions: {shortcuts: [{text: '最近一个月',onClick(picker) {const end = new Date()const start = new Date()start.setTime(start.getTime() - 3600 * 1000 * 24 * 30)picker.$emit('pick', [start, end])}},{text: '最近三个月',onClick(picker) {const end = new Date()const start = new Date()start.setTime(start.getTime() - 3600 * 1000 * 24 * 90)picker.$emit('pick', [start, end])}},{text: '最近一年',onClick(picker) {const end = new Date()const start = new Date()start.setTime(start.getTime() - 3600 * 1000 * 24 * 365)picker.$emit('pick', [start, end])}}]}}},components: {Left,Center,Right},created() {if (localStorage.hasOwnProperty('figure-bg')) {// 初始化背景this.figureBG = localStorage.getItem('figure-bg')if (this.figureBG == 0) {this.color = ['#568aea', '#0e2140']}}},mounted() {for (let i = 0; i <= 4; i++) {setTimeout(() => {if (i == 4) {this.isShowLoading = falsethis.$nextTick(() => {this.init()})return}let num = i == 3 ? 100 : parseInt(Math.random() * 15) + 50 + 15 * ithis.configLoad = {number: [num],content: '{nt}%',style: {fontSize: 18,fill: '#3de7c9'}}}, i * 100)}},methods: {init() {// 传入时间,组件根据时间重新获取数据if (Object.is(this.date, null) || !(this.date instanceof Array)) {return}let start = new Date(this.date[0])let end = new Date(this.date[1])start = `${start.getFullYear()}-${this.fillNum(start.getMonth() + 1)}-${this.fillNum(start.getDate())} 00:00:00`end = `${end.getFullYear()}-${this.fillNum(end.getMonth() + 1)}-${this.fillNum(end.getDate())} 23:59:59`this.$refs.left.componentInit(start, end)this.$refs.center.componentInit(start, end)this.$refs.right.componentInit(start, end)},fillNum(num, size = 2) {return String.prototype.padStart.call(num, size, '0')},handleScreenfull() {if (!screenfull.isEnabled) {this.$message.error('您的浏览器无法使用全屏功能,请更换谷歌浏览器或者请手动点击F11按钮全屏展示!')

这篇关于vue 项目下使用dataV和echarts 开发可视化大屏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/277593

相关文章

Java使用ANTLR4对Lua脚本语法校验详解

《Java使用ANTLR4对Lua脚本语法校验详解》ANTLR是一个强大的解析器生成器,用于读取、处理、执行或翻译结构化文本或二进制文件,下面就跟随小编一起看看Java如何使用ANTLR4对Lua脚本... 目录什么是ANTLR?第一个例子ANTLR4 的工作流程Lua脚本语法校验准备一个Lua Gramm

Java Optional的使用技巧与最佳实践

《JavaOptional的使用技巧与最佳实践》在Java中,Optional是用于优雅处理null的容器类,其核心目标是显式提醒开发者处理空值场景,避免NullPointerExce... 目录一、Optional 的核心用途二、使用技巧与最佳实践三、常见误区与反模式四、替代方案与扩展五、总结在 Java

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

Qt中QUndoView控件的具体使用

《Qt中QUndoView控件的具体使用》QUndoView是Qt框架中用于可视化显示QUndoStack内容的控件,本文主要介绍了Qt中QUndoView控件的具体使用,具有一定的参考价值,感兴趣的... 目录引言一、QUndoView 的用途二、工作原理三、 如何与 QUnDOStack 配合使用四、自

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

前端CSS Grid 布局示例详解

《前端CSSGrid布局示例详解》CSSGrid是一种二维布局系统,可以同时控制行和列,相比Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,:本文主要介绍前端CSSGri... 目录css Grid 布局详解(通俗易懂版)一、概述二、基础概念三、创建 Grid 容器四、定义网格行和列五、设置行

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/