亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

手把手教你Vue3?按需引入?Echarts的過程(收藏)

 更新時間:2023年10月14日 10:06:01   作者:趙花花5070  
新項目采用?Vue3?作為前端項目框架,避免不了要使用?echarts,但是在使用的時候,出現(xiàn)了與?Vue2?使用不一樣的地方,所以特別記下來,希望給到有需要的同學(xué)一些幫助

背景:新項目采用 Vue3 作為前端項目框架,避免不了要使用 echarts,但是在使用的時候,出現(xiàn)了與 Vue2 使用不一樣的地方,所以特別記下來,希望給到有需要的同學(xué)一些幫助。

下載Echarts依賴

# 自己使用的yarn
yarn add echarts
# or
npm install echarts --save
 # or
# 有淘寶鏡像的可以選擇  (安裝速度快)
cnpm install echarts --save

創(chuàng)建按需引入的配置文件 echarts.ts(文件名稱自定義)及進(jìn)行配置

在你自己需要的目錄下創(chuàng)建引入 eachrts 配置的文件,我是在 src/utils 目錄下創(chuàng)建的 echarts.ts 文件(根據(jù)你自己的需求)在echarts.ts文件中引入echarts相關(guān)配置,網(wǎng)上有很多教程,但這里還是再啰嗦寫一下,做戲做全套,一條龍服務(wù)。(看到最后有用給個點贊+收藏)

// 引入 echarts 核心模塊,核心模塊提供了 echarts 使用必須要的接口。
import * as echarts from "echarts/core";

/** 引入柱狀圖 + 折線圖 + 餅圖,圖表后綴都為 Chart,一般常用的就這三個,如果還需要其他的,就自行添加  */
import { BarChart, LineChart, PieChart } from "echarts/charts";

// 引入提示框,標(biāo)題,直角坐標(biāo)系,數(shù)據(jù)集,內(nèi)置數(shù)據(jù)轉(zhuǎn)換器組件,組件后綴都為 Component
import {
  TitleComponent,
  TooltipComponent,
  GridComponent,
  DatasetComponent,
  TransformComponent,
  ToolboxComponent,
  LegendComponent,
} from "echarts/components";

// 標(biāo)簽自動布局,全局過渡動畫等特性
import { LabelLayout, UniversalTransition } from "echarts/features";

// 引入 Canvas 渲染器,注意引入 CanvasRenderer 或者 SVGRenderer 是必須的一步
import { CanvasRenderer } from "echarts/renderers";

// 注冊必須的組件
echarts.use([
  TitleComponent,
  TooltipComponent,
  GridComponent,
  DatasetComponent,
  TransformComponent,
  ToolboxComponent,
  LegendComponent,
  LabelLayout,
  UniversalTransition,
  CanvasRenderer,
  BarChart,
  LineChart,
  PieChart,
]);

// 導(dǎo)出
export default echarts;


根目錄 main.ts 文件引入創(chuàng)建的配置文件 echarts.ts

項目另外采用了 Pinia + ElementPlus + ElementPlus(圖標(biāo)),引入方式都在下面,希望能夠得到有需要的朋友幫助。

最重要的是要看本次引入echarts相關(guān)配置部分,注釋也寫好了,大家可以參考一下。

import { createApp } from "vue";
import { createPinia } from "pinia";

// 引入Element-plus
import ElementPlus from "element-plus";
import "element-plus/dist/index.css";
import zhCn from "element-plus/dist/locale/zh-cn.mjs";

// 引入圖標(biāo)
import * as ElementPlusIconsVue from "@element-plus/icons-vue";

// 引入路由
import router from "./routes/index";

// 引入echarts
import echarts from "./utils/echarts";

// 引入整個項目入口文件
import App from "./App.vue";

// 定義全局樣式
import "./style.less";

// 創(chuàng)建 Store 實例
const piniaStore = createPinia();

// 創(chuàng)建Vue實例
const app = createApp(App);

// 注冊 Element-plus圖標(biāo)
for (const [key, component] of Object.entries(ElementPlusIconsVue)) {
  app.component(key, component);
}

/***********************echart 掛載 START*******************************/

// echarts 掛載到 Vue實例中
// 注意:app.config.globalProperties 和 app.provide('$echarts', echarts) 二選一即可
// Vue.prototype.$echarts = echarts; // vue2的掛載方式

app.config.globalProperties.$echarts = echarts; // vue3的掛載方式(一個用于注冊能夠被應(yīng)用內(nèi)所有組件實例訪問到的全局屬性的對象。)

app.provide('$echarts', echarts); // vue3采用provide, inject方式使用

/***********************echart 掛載 END*******************************/

// 掛載element-plus,使用國際化,設(shè)置圖標(biāo)尺寸,及彈框?qū)蛹?
app.use(router).use(piniaStore).use(ElementPlus, {
  // size: 'small',
  zIndex: 3000,
  locale: zhCn,
});

// vue掛載到根節(jié)點
app.mount("#app");


組件內(nèi)使用echarts

前面基本都還簡單,但是到了使用的時候,很多人就不知道怎么處理了,以前在 Vue2 的時候還可以通過vue實例 拿到 this 去使用,但是到了 Vue3 里面,沒有this 了,怎么辦?

不著急,辦法還是有的,并且還不止一種,請接著往下看。

1.通過 getCurrentInstance() 獲取組件實例,類似 Vue2 中的 this

<script setup lang="ts">
	import { ref, getCurrentInstance } from 'vue';
	
	// 獲取echart掛載的DOM節(jié)點
	const container = ref();
	
	// 獲取當(dāng)前組件實例
	const { proxy }: any = getCurrentInstance();
	
	// echarts初始化
	let myChart = proxy.$echarts.init(container.value);
	
	const option = {
		// 自定義echarts圖標(biāo)相關(guān)配置
	};
	
	myChart.setOption(option);
	
	// 根據(jù)頁面大小自動響應(yīng)圖表大小
	window.addEventListener("resize", function () {
	    myChart.resize();
	});
	
</script>

<template>
	<div id="echarts1" ref="container"></div>
</template>

2.通過采用provide, inject方式使用

<script setup lang="ts">
	import { ref, inject} from 'vue';
	
	// 獲取echart掛載的DOM節(jié)點
	const container = ref();

	// 通過 inject 接收Echarts
	const Echarts = inject('$echarts');

	// echarts初始化
	const myChart = (Echarts as any).init(container.value);

	const option = {
		// 自定義echarts圖標(biāo)相關(guān)配置
	};
	
	myChart.setOption(option);
	
	// 根據(jù)頁面大小自動響應(yīng)圖表大小
	window.addEventListener("resize", function () {
	    myChart.resize();
	});
</script>

<template>
	<div id="echarts1" ref="container"></div>
</template>

上面的兩種方式唯一不同的就是如何獲?。ń邮眨┳詄charts。

到這里就結(jié)束了嗎?

問題解決

太天真了!

這里我就要問下,上面兩種方式的代碼能夠跑起來嗎?

事實上,不行,因為上面 script 內(nèi)的代碼運行的時候,還沒有掛載到組件實例上,找不到定義的 ref 對象 container,即使通過document.getElementById('echarts1') 的方式獲取DOM節(jié)點 <div id="echarts1" ref="container"></div> 一樣報 null 或者 undefined。

子任就會出現(xiàn)如下報錯:Uncaught (in promise) Error: Initialize failed: invalid dom.

不信? 那么就控制臺打印輸出看看兩種方式獲取的DOM到底是個啥。

<script setup lang="ts">
	import { ref } from 'vue';
	
	// 獲取echart掛載的DOM節(jié)點
	const container = ref();
	console.log('獲取的DOM-div:', document.getElementById('echarts1'), container.value);
	
</script>

<template>
	<div id="echarts1" ref="container"></div>
</template>

上面的代碼輸出一下結(jié)果:

那么解決辦法也很簡單,直接開啟一個延時器 setTimeout 就好了。

最后完整代碼如下:

<script setup lang="ts">
	import { ref, inject, onBeforeUnmount} from 'vue';
	
	// 獲取echart掛載的DOM節(jié)點
	const container = ref();
	
	// 定義延時器指針對象,便于組件實例銷毀的時候以便清除
	const timer = ref();

	// 通過 inject 接收Echarts
	const Echarts = inject('$echarts');
	
	// 或
	// 通過Vue全局注冊方式獲取
	// const {proxy}: any = getCurrentInstance();
	

	const initEchartsOneFn = () => {
		// echarts初始化
		const myChart = (Echarts as any).init(container.value);

		// 或
		// let myChart = proxy.$echarts.init(container.value);
	
		const option = {
			// 自定義echarts圖標(biāo)相關(guān)配置
		};
		
		myChart.setOption(option);
		
		// 根據(jù)頁面大小自動響應(yīng)圖表大小
		window.addEventListener("resize", function () {
		    myChart.resize();
		});
	}

	// 判斷定時器是否存在
	if (timer.value) {
	    clearTimeout(timer.value);
	}
	
	// 綁定定時器,銷毀的時候再次清除
	timer.value = setTimeout(() => initEchartsOneFn(), 1000);
	
	// 組件實例銷毀前清除延時器對象
	onBeforeUnmount(() => {
	    if (timer.value) clearTimeout(timer.value);
	});
</script>

// 此處部分將就著看看
<template>
	<div id="echarts1" ref="container"></div>
</template>

以證清白,上效果圖:

最后

到此這篇關(guān)于Vue3 手把手按需引入 Echarts的文章就介紹到這了,更多相關(guān)Vue按需引入 Echarts內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue Element前端應(yīng)用開發(fā)之前端API接口的封裝

    Vue Element前端應(yīng)用開發(fā)之前端API接口的封裝

    對整個系統(tǒng)來說,一般會有很多業(yè)務(wù)對象,而每個業(yè)務(wù)對象的API接口又有很多。我們這個VUE+Element 前端應(yīng)用就是針對ABP框架的業(yè)務(wù)對象,因此前端的業(yè)務(wù)對象接口也是比較統(tǒng)一的,那么可以考慮在前端中對后端API接口調(diào)用進(jìn)行封裝,引入ES6的方式進(jìn)行前端API的抽象簡化。
    2021-05-05
  • 在Vue3項目中安裝和配置Three.js的操作代碼

    在Vue3項目中安裝和配置Three.js的操作代碼

    Three.js是一個輕量級的WebGL封裝庫,用于在瀏覽器中渲染復(fù)雜的3D圖形,它提供了便捷的API,可以快速構(gòu)建3D場景、對象和動畫,Vue.js是一個漸進(jìn)式JavaScript框架,擅長構(gòu)建用戶界面,本文給大家介紹了在Vue3項目中安裝和配置Three.js的操作,需要的朋友可以參考下
    2024-12-12
  • vue使用中的內(nèi)存泄漏【推薦】

    vue使用中的內(nèi)存泄漏【推薦】

    內(nèi)存泄露是指new了一塊內(nèi)存,但無法被釋放或者被垃圾回收。這篇文章主要介紹了vue使用中的內(nèi)存泄漏,需要的朋友可以參考下
    2018-07-07
  • vue商城中商品“篩選器”功能的實現(xiàn)代碼

    vue商城中商品“篩選器”功能的實現(xiàn)代碼

    這篇文章主要介紹了vue商城中商品“篩選器”功能的實現(xiàn),本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • Vue中qs插件的使用詳解

    Vue中qs插件的使用詳解

    這篇文章主要介紹了Vue中qs插件的使用詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • Vue3中實現(xiàn)微信掃碼登錄的步驟和代碼示例

    Vue3中實現(xiàn)微信掃碼登錄的步驟和代碼示例

    在 Vue 3 中實現(xiàn)微信掃碼登錄,涉及到前端生成二維碼、監(jiān)聽微信回調(diào)以及與后端的交互,本文給大家介紹了一個詳細(xì)的實現(xiàn)步驟和代碼示例,對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-07-07
  • 解決echarts數(shù)據(jù)二次渲染不成功的問題

    解決echarts數(shù)據(jù)二次渲染不成功的問題

    這篇文章主要介紹了解決echarts數(shù)據(jù)二次渲染不成功的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • vue里面v-bind和Props 利用props綁定動態(tài)數(shù)據(jù)的方法

    vue里面v-bind和Props 利用props綁定動態(tài)數(shù)據(jù)的方法

    今天小編就為大家分享一篇vue里面v-bind和Props 利用props綁定動態(tài)數(shù)據(jù)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • Vue3+Vite+TS使用elementPlus時踩的坑及解決

    Vue3+Vite+TS使用elementPlus時踩的坑及解決

    這篇文章主要介紹了Vue3+Vite+TS使用elementPlus時踩的坑及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue3+vite+移動端webview打包后頁面加載空白問題解決辦法

    vue3+vite+移動端webview打包后頁面加載空白問題解決辦法

    這篇文章主要給大家介紹了關(guān)于vue3+vite+移動端webview打包后頁面加載空白問題的解決辦法,文中通過代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2024-06-06

最新評論