Vue3 將組件手動(dòng)渲染到指定元素中的方法實(shí)現(xiàn)
一些第三方庫(kù)內(nèi)部創(chuàng)建的元素,并不是由 Vue 管理的。比如 ECharts,Antv 等圖表庫(kù)中的自定義圖形節(jié)點(diǎn)。這些庫(kù)或許支持使用 HTML 自定義圖表中的某一部分,但僅僅書寫 HTML 并不那么令人滿意。
我希望將一個(gè)組件手動(dòng)掛載到指定元素上,可以嘗試兩種方式:自定義元素,多應(yīng)用。
將組件轉(zhuǎn)換為自定義元素
文檔:Vue 與 Web Components | Vue.js (vuejs.org)
Vue 對(duì) Web Components 提供了良好的支持??梢允褂?code>defineCustomElement將組件轉(zhuǎn)換為自定義元素。隨后就可以自由插入到 DOM 節(jié)點(diǎn)中了。
import { defineCustomElement } from 'vue' const MyVueElement = defineCustomElement({ // 這里是同平常一樣的 Vue 組件選項(xiàng) props: {}, emits: {}, template: `...`, // defineCustomElement 特有的:注入進(jìn) shadow root 的 CSS styles: [`/* inlined css */`] }) // 注冊(cè)自定義元素 // 注冊(cè)之后,所有此頁(yè)面中的 `<my-vue-element>` 標(biāo)簽 // 都會(huì)被升級(jí) customElements.define('my-vue-element', MyVueElement) // 你也可以編程式地實(shí)例化元素: // (必須在注冊(cè)之后) document.body.appendChild( new MyVueElement({ // 初始化 props(可選) }) )
此外,還可以將一個(gè) SFC (單文件組件)轉(zhuǎn)換為自定義元素。
import { defineCustomElement } from 'vue' import Example from './Example.ce.vue' console.log(Example.styles) // ["/* 內(nèi)聯(lián) css */"] // 轉(zhuǎn)換為自定義元素構(gòu)造器 const ExampleElement = defineCustomElement(Example) // 注冊(cè) customElements.define('my-example', ExampleElement)
值得注意的是,
defineCustomElement
會(huì)使用 Shadow DOM 渲染元素。而這種方式會(huì)造成樣式隔離,外部的樣式將無(wú)法作用到組件內(nèi)部。 如果您使用了組件庫(kù),或依賴于某些外部樣式,記得將這些樣式重復(fù)導(dǎo)入一次。
Vue 的多應(yīng)用實(shí)例
還記得在創(chuàng)建項(xiàng)目時(shí),我們使用了createApp
創(chuàng)建一個(gè)App
實(shí)例,然后將它掛載到了#app
里。實(shí)際上,在一個(gè) DOM 環(huán)境中可以同時(shí)存在多個(gè) App 實(shí)例,也就是多個(gè) Vue 應(yīng)用。
利用這一點(diǎn),可以再次創(chuàng)建一個(gè) App 實(shí)例,然后將它掛載到某個(gè)特定的 DOM 元素上。
import YouComponent from "./YouComponent.vue"; // 創(chuàng)建一個(gè)新的 Vue 應(yīng)用 const app = createApp(YouComponent); // 將應(yīng)用掛載到自定義的 DOM 元素上 app.mount("#you-element");
這樣,組件就可以正常渲染了。但是組件的 provide,inject 會(huì)失效,因?yàn)樗⒉粚儆谠鹊膽?yīng)用了。
如何進(jìn)行組件之間的通信?可以使用自定義事件,或者 createEventHook | VueUse。 此外,也可以利用 Vue3 的響應(yīng)性原理,使用
ref
或者reactive
創(chuàng)建一個(gè)單獨(dú)的響應(yīng)性對(duì)象,然后在不同的組件中引用它們,就可以實(shí)現(xiàn)雙向的數(shù)據(jù)同步。
到此這篇關(guān)于Vue3 將組件手動(dòng)渲染到指定元素中的方法實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Vue3 渲染組件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解vue-cli + webpack 多頁(yè)面實(shí)例配置優(yōu)化方法
本篇文章主要介紹了詳解vue-cli + webpack 多頁(yè)面實(shí)例配置優(yōu)化方法,具有一定的參考價(jià)值,有興趣的可以了解一下2017-07-07vue項(xiàng)目中解決 IOS + H5 滑動(dòng)邊界橡皮筋彈性效果(解決思路)
最近遇到一個(gè)問(wèn)題,我們?cè)谄髽I(yè)微信中的 H5 項(xiàng)目中需要用到table表格(支持懶加載 上劃加載數(shù)據(jù)),但是他們?cè)阪i頭、鎖列的情況下,依舊會(huì)出現(xiàn)邊界橡皮筋效果,這篇文章主要介紹了vue項(xiàng)目中解決 IOS + H5 滑動(dòng)邊界橡皮筋彈性效果,需要的朋友可以參考下2023-02-02如何讓別人訪問(wèn)本地運(yùn)行的vue項(xiàng)目
這篇文章主要介紹了如何讓別人訪問(wèn)本地運(yùn)行的vue項(xiàng)目,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10vue中使用mixins/extends傳入?yún)?shù)的方式
這篇文章主要介紹了vue中使用mixins/extends傳入?yún)?shù)的方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05Vue+Element-ui彈窗?this.$alert?is?not?a?function問(wèn)題
這篇文章主要介紹了Vue+Element-ui彈窗?this.$alert?is?not?a?function問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10Vue項(xiàng)目中v-bind動(dòng)態(tài)綁定src路徑不成功問(wèn)題及解決
這篇文章主要介紹了Vue項(xiàng)目中v-bind動(dòng)態(tài)綁定src路徑不成功問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04