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