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 for循環(huán)出來(lái)的數(shù)據(jù)實(shí)現(xiàn)用逗號(hào)隔開
HTML(HyperText Markup Language)是用于創(chuàng)建網(wǎng)頁(yè)的標(biāo)準(zhǔn)標(biāo)記語(yǔ)言,正確的HTML編碼和結(jié)構(gòu)對(duì)于網(wǎng)頁(yè)的正確顯示至關(guān)重要,當(dāng)HTML代碼正確無(wú)誤時(shí),網(wǎng)頁(yè)的效果圖將與設(shè)計(jì)師的預(yù)期相符,反之則可能出現(xiàn)布局錯(cuò)亂、樣式失效等問(wèn)題2024-10-10
vue.js實(shí)現(xiàn)點(diǎn)擊后動(dòng)態(tài)添加class及刪除同級(jí)class的實(shí)現(xiàn)代碼
這篇文章主要介紹了vue.js實(shí)現(xiàn)點(diǎn)擊后動(dòng)態(tài)添加class及刪除同級(jí)class的相關(guān)資料,需要的朋友可以參考下2018-04-04
ant-design-vue導(dǎo)航菜單a-menu的使用解讀
這篇文章主要介紹了ant-design-vue導(dǎo)航菜單a-menu的使用解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10
Vue中splice()方法對(duì)數(shù)組進(jìn)行增刪改等操作的實(shí)現(xiàn)
vue中對(duì)數(shù)組的元素進(jìn)行刪除,以前一直以為這個(gè)方法是vue中特有的,后來(lái)百度之后才知道原來(lái)是js的一個(gè)寫法,下面這篇文章主要給大家介紹了關(guān)于Vue中splice()方法對(duì)數(shù)組進(jìn)行增刪改等操作的實(shí)現(xiàn)方法,需要的朋友可以參考下2023-05-05
Vue開發(fā)實(shí)現(xiàn)吸頂效果的示例代碼
這篇文章主要介紹了Vue開發(fā)實(shí)現(xiàn)吸頂效果的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-08-08
vue如何解決代碼需要在dom渲染之后執(zhí)行問(wèn)題
這篇文章主要介紹了vue如何解決代碼需要在dom渲染之后執(zhí)行問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03

