Vue?Echarts實(shí)現(xiàn)實(shí)時(shí)大屏動(dòng)態(tài)數(shù)據(jù)顯示
前言
因?yàn)槭菄缶€上應(yīng)用的活動(dòng)大屏,我就不附圖了。代碼僅供參考。
一、vue配置
1. 我是用vue-cli 搭建的,大屏項(xiàng)目復(fù)雜度不高,vue-router、vuex 、axios、sass 等都可以不用,vue、echarts就夠用。
2. vue.config.js 配置就正常配,出口入口等基本配置我就不展示了,這兩個(gè)配置項(xiàng)大屏還有點(diǎn)用。主要是我把每個(gè)圖表都拆成了單獨(dú)的組件,沒封裝公共的圖表組件,一些重復(fù)的樣式還有一些scss的函數(shù)可以寫在公共的文件里,我是開發(fā)環(huán)境用了sass。
module.exports = { configureWebpack: { name: "", // 打包后的瀏覽器的title, 大屏全屏展示了用處不大 resolve: { alias: { '@': resolve('src') } } }, css: { // 全局公共css loaderOptions: { sass: { prependData: `@import "@/styles/index.scss";` // 這個(gè)是在每個(gè)css文件加個(gè)前置代碼 } } } }
二、適配方案
既然是大屏,肯定是要適配滴。適配方案網(wǎng)上很多很多,我不過多介紹,我只說下我真正使用的方案。以下代碼放到一個(gè)js文件里,然后在main.js里引入,自執(zhí)行函數(shù)直接解決這個(gè)適配問題,js的好處就是不限于你所使用的js框架。適配過后單位可采用px和百分比。flex布局簡單將大屏分割一個(gè)圖表為一個(gè)組件,拼出來就好了。
(function (win) { var bodyStyle = document.createElement('style') bodyStyle.innerHTML = `body{width:1920px; height:1080px!important;overflow: hidden}` document.documentElement.firstElementChild.appendChild(bodyStyle) function refreshScale() { let docWidth = document.documentElement.clientWidth; let docHeight = document.documentElement.clientHeight; //設(shè)計(jì)圖的寬高 var designWidth = 1920, designHeight = 1080, widthRatio = docWidth / designWidth, heightRatio = docHeight / designHeight; //設(shè)置縮放屬性 document.body.style = "transform:scale(" + widthRatio + "," + heightRatio + ");transform-origin:left top;" // 應(yīng)對瀏覽器全屏切換前后窗口因短暫滾動(dòng)條問題出現(xiàn)未占滿情況 setTimeout(function () { var lateWidth = document.documentElement.clientWidth, lateHeight = document.documentElement.clientHeight; if (lateWidth === docWidth) return; widthRatio = lateWidth / designWidth heightRatio = lateHeight / designHeight document.body.style = "transform:scale(" + widthRatio + "," + heightRatio + ");transform-origin:left top;" }, 0) } refreshScale() win.addEventListener("pageshow", function (e) { if (e.persisted) { // 瀏覽器后退的時(shí)候重新計(jì)算 refreshScale() } }, false); //監(jiān)聽頁面變化 win.addEventListener("resize", refreshScale, false); })(window)
三、Echarts
1. echarts 官網(wǎng)對于api 和 option 的解釋很清晰全面,看官網(wǎng)解決大部分問題。
2. 圖表option 可能存在大量重復(fù)配置項(xiàng),比如整個(gè)大屏風(fēng)格顏色,可以把公共的抽離成一個(gè)js對象,然后利用對象合并,既保證了代碼簡潔,后面修改和維護(hù)也方便。
3.圖表適配問題,圖表適配保證視口變化,圖表不會(huì)變得扭曲。在根組件App.vue監(jiān)聽一下。update 通過 prop分發(fā)給每個(gè)圖表組件。時(shí)間戳保證更新狀態(tài)。
mounted() { window.addEventListener("resize", () => { this.update = new Date().getTime(); }); }
圖表所在組件監(jiān)聽一下變化,調(diào)用echarts內(nèi)置函數(shù)resize。
watch: { upDate() { this.myEchart && this.myEchart.resize(); } }
4. echarts 地圖問題,地圖的話echarts5.0.0以后的版本往后應(yīng)該是不內(nèi)置了,我下載了4.9.0版本的。最開始我下載的也是最新的,發(fā)現(xiàn)這個(gè)問題,我就降版本了。
import * as echarts from "echarts"; import "echarts/map/js/china.js";
這樣就可以配置地圖了,比較新的版本,不降版本也行,你網(wǎng)上找一份這個(gè)地圖js文件,放到項(xiàng)目里也可以。
四、實(shí)時(shí)更新
實(shí)時(shí)更新怎么做,就是輪詢。將請求過來的數(shù)據(jù)在App.vue 組件利用prop分發(fā)給每個(gè)圖表組件。watch監(jiān)聽一下(deep),重新 init 圖表。記得銷毀定時(shí)器。
wheel() { this.timer = setInterval(() => { console.log("輪詢調(diào)用接口中..."); this.queryData(); }, 60000); // 6秒一次 }, queryData() { // 請求接口 沒用axios就用fetch },
到此這篇關(guān)于Vue Echarts實(shí)現(xiàn)實(shí)時(shí)大屏動(dòng)態(tài)數(shù)據(jù)顯示的文章就介紹到這了,更多相關(guān)Vue Echarts內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue 集成 PDF.js 實(shí)現(xiàn) PDF 預(yù)覽和添加水印的步驟
這篇文章主要介紹了如何在 Vue 中集成 Mozilla/PDF.js ,實(shí)現(xiàn)自定義的 PDF 預(yù)覽器,以及給被預(yù)覽的 PDF 添加水印2021-01-01vue實(shí)現(xiàn)頁面渲染時(shí)候執(zhí)行某需求的示例代碼
本文主要介紹了vue實(shí)現(xiàn)頁面渲染時(shí)候執(zhí)行某需求,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-05-05vue keep-alive請求數(shù)據(jù)的方法示例
本篇文章主要介紹了vue keep-alive請求數(shù)據(jù)的方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05vue大屏自適應(yīng)的實(shí)現(xiàn)方法(cv就能用)
最近在用VUE寫大屏頁面,遇到屏幕自適應(yīng)問題,下面這篇文章主要給大家介紹了關(guān)于vue大屏自適應(yīng)的實(shí)現(xiàn)方法,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06Vue+springboot批量刪除功能實(shí)現(xiàn)代碼
這篇文章主要介紹了Vue+springboot批量刪除功能,本文通過示例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧2024-05-05vue實(shí)現(xiàn)子路由調(diào)用父路由的方法
這篇文章主要介紹了vue實(shí)現(xiàn)子路由調(diào)用父路由的方法,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06在vue項(xiàng)目中引入highcharts圖表的方法
今天小編就為大家分享一篇關(guān)于在vue項(xiàng)目中引入highcharts圖表的方法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-01-01詳解VUE-地區(qū)選擇器(V-Distpicker)組件使用心得
這篇文章主要介紹了詳解VUE-地區(qū)選擇器(V-Distpicker)組件使用心得,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05element-plus/element-ui走馬燈配置圖片及圖片自適應(yīng)的最簡便方法
走馬燈功能在展示圖片時(shí)經(jīng)常用到,下面這篇文章主要給大家介紹了關(guān)于element-plus/element-ui走馬燈配置圖片及圖片自適應(yīng)的最簡便方法,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03