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 开发可视化大屏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/qq_45950523/article/details/127867780
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/277593

相关文章

Python使用python-docx实现自动化处理Word文档

《Python使用python-docx实现自动化处理Word文档》这篇文章主要为大家展示了Python如何通过代码实现段落样式复制,HTML表格转Word表格以及动态生成可定制化模板的功能,感兴趣的... 目录一、引言二、核心功能模块解析1. 段落样式与图片复制2. html表格转Word表格3. 模板生

go rate 原生标准限速库的使用

《gorate原生标准限速库的使用》本文主要介绍了Go标准库golang.org/x/time/rate实现限流,采用令牌桶算法控制请求速率,提供Allow/Reserve/Wait方法,具有一定... 目录介绍安装API介绍rate.NewLimiter:创建限流器limiter.Allow():请求是否

JavaScript实战:智能密码生成器开发指南

本文通过JavaScript实战开发智能密码生成器,详解如何运用crypto.getRandomValues实现加密级随机密码生成,包含多字符组合、安全强度可视化、易混淆字符排除等企业级功能。学习密码强度检测算法与信息熵计算原理,获取可直接嵌入项目的完整代码,提升Web应用的安全开发能力 目录

Python使用Turtle实现精确计时工具

《Python使用Turtle实现精确计时工具》这篇文章主要为大家详细介绍了Python如何使用Turtle实现精确计时工具,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录功能特点使用方法程序架构设计代码详解窗口和画笔创建时间和状态显示更新计时器控制逻辑计时器重置功能事件

Swagger2与Springdoc集成与使用详解

《Swagger2与Springdoc集成与使用详解》:本文主要介绍Swagger2与Springdoc集成与使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1. 依赖配置2. 基础配置2.1 启用 Springdoc2.2 自定义 OpenAPI 信息3.

golang实现动态路由的项目实践

《golang实现动态路由的项目实践》本文主要介绍了golang实现动态路由项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习... 目录一、动态路由1.结构体(数据库的定义)2.预加载preload3.添加关联的方法一、动态路由1

Golang interface{}的具体使用

《Golanginterface{}的具体使用》interface{}是Go中可以表示任意类型的空接口,本文主要介绍了Golanginterface{}的具体使用,具有一定的参考价值,感兴趣的可以了... 目录一、什么是 interface{}?定义形China编程式:二、interface{} 有什么特别的?✅

使用Python实现调用API获取图片存储到本地的方法

《使用Python实现调用API获取图片存储到本地的方法》开发一个自动化工具,用于从JSON数据源中提取图像ID,通过调用指定API获取未经压缩的原始图像文件,并确保下载结果与Postman等工具直接... 目录使用python实现调用API获取图片存储到本地1、项目概述2、核心功能3、环境准备4、代码实现

windows和Linux安装Jmeter与简单使用方式

《windows和Linux安装Jmeter与简单使用方式》:本文主要介绍windows和Linux安装Jmeter与简单使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows和linux安装Jmeter与简单使用一、下载安装包二、JDK安装1.windows设

Spring 缓存在项目中的使用详解

《Spring缓存在项目中的使用详解》Spring缓存机制,Cache接口为缓存的组件规范定义,包扩缓存的各种操作(添加缓存、删除缓存、修改缓存等),本文给大家介绍Spring缓存在项目中的使用... 目录1.Spring 缓存机制介绍2.Spring 缓存用到的概念Ⅰ.两个接口Ⅱ.三个注解(方法层次)Ⅲ.