關于Vue中echarts響應式頁面變化resize()的用法介紹
前言
Vue項目中開發(fā)數(shù)據(jù)大屏,使用echarts圖表根據(jù)不同尺寸的屏幕進行適配
BUG:當頁面進行縮放時圖表大小沒有變化
- 使用到的方法:
resize() 調(diào)用echarts中內(nèi)置的resize函數(shù)進行自適應縮放,然后添加監(jiān)控,頁面銷毀時刪掉,避免不必要內(nèi)存占用 - 我們先看一下官方文檔怎么說resize官網(wǎng)
- 響應的原理:需要手動調(diào)用 resize 方法獲取正確的高寬并且刷新畫布
億點小知識:可以在opts 中顯示指定圖表高寬
- 實戰(zhàn) vue3.0
1.創(chuàng)建容器
<div ref="myChart" style="width:100%;height:100%"></div>
2.創(chuàng)建echarts
先創(chuàng)建一個 echartsLine.ts 文件
import { EChartsOption } from "echarts"; const exportFuns = (): EChartsOption => { return { xAxis: { type: 'category', data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] }, yAxis: { type: 'value' }, series: [ { data: [150, 230, 224, 218, 135, 147, 260], type: 'line' } ] } }; export const EchartsLineConsumption = exportFuns();
在容器組件里面應用echartsLine.ts 文件
<script lang="ts" setup> import { ref, onMounted, markRaw } from "vue"; import * as echarts from "echarts"; import { EchartsLineConsumption } from "@/config/echartsLine"; const myChart = ref<any>(); // 獲取元素實例 const line = ref<any>(null); // 獲取echarts onMounted(() => { init(); }); const init = ()=>{ line.value = markRaw(echarts.init(myChart.value)); line.value.setOption(EchartsLineConsumption); } </script>
3.進行響應式頁面變化.resize()
onMounted(() => { // 只要窗口大小發(fā)生像素變化就會觸發(fā) window.addEventListener("resize", () => { line.value.resize(); // 窗口發(fā)生改變就更新echarts }); init(); });
4.需要進行銷毀實例優(yōu)化性能
onUnmounted(() => { // 卸載echarts實例 line.value.dispose(); window.removeEventListener("resize", line.value); });
以上就完成了 Vue中 echarts響應式頁面變化
接下來總結(jié)了一下echarts的一些常用知識
- 在餅圖中間添加文字
1.富文本 比較麻煩
2.在series的label中
type: "pie", radius: ["47%", "57%"], // 讓餅圖中間為空心狀 label: { show: true, position: "center", formatter: "中間圓心內(nèi)容", fontSize: '18px', },
- 讓圖表占滿容器
使用grid屬性
grid: { // 讓圖表占滿容器 left: 0, right: 0, bottom: 0, containLabel: true, },
- 自定義移入樣式
marker屬性
tooltip: { position: "top", show: true, formatter: (params) => { //只有“直接訪問”使用大標簽,其他都使用小標簽 return `$標題<br/>${params.marker}`;//marker 圖標 }, // extraCssText:'width:60px;white-space:pre-wrap' },
- legend顯示和位置
bottom和left調(diào)整位置
circle::讓前面顯示的為圓形
itemGap:顯示之間的間距
legend: { orient: "horizontal", bottom: '5px', left: "left", icon: "circle", itemGap: 2, },
以上就是echarts響應式頁面變化.resize()感謝大家的閱讀
到此這篇關于關于Vue中echarts響應式頁面變化resize()的用法介紹的文章就介紹到這了,更多相關Vue頁面變化resize()內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Vue.js做select下拉列表的實例(ul-li標簽仿select標簽)
下面小編就為大家分享一篇Vue.js做select下拉列表的實例(ul-li標簽仿select標簽),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03vue啟動后請求后端接口報ERR_EMPTY_RESPONSE錯誤的解決
這篇文章主要介紹了vue啟動后請求后端接口報ERR_EMPTY_RESPONSE錯誤的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05前端文件導出設置responseType為blob時遇到的問題及解決
這篇文章主要給大家介紹了關于前端文件導出設置responseType為blob時遇到的問題及解決方法,文中通過圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-09-09Vue路由跳轉(zhuǎn)傳參或打開新頁面跳轉(zhuǎn)的方法總結(jié)
這篇文章主要給大家介紹了關于Vue路由跳轉(zhuǎn)傳參或打開新頁面跳轉(zhuǎn)的相關資料,在使用Vue.js開發(fā)單頁面應用時常常會遇到路由跳轉(zhuǎn)傳參的需求,需要的朋友可以參考下2023-07-07Electron主進程(Main?Process)與渲染進程(Renderer?Process)通信詳解
這篇文章主要介紹了Electron主進程(Main?Process)與渲染進程(Renderer?Process)通信,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03