欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue3 將組件手動(dòng)渲染到指定元素中的方法實(shí)現(xiàn)

 更新時(shí)間:2023年04月23日 10:24:43   作者:Fisschl  
本文主要介紹了Vue3 將組件手動(dòng)渲染到指定元素中的方法實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

一些第三方庫(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)換為自定義元素。

文檔:sfc as custom element

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中v-mode詳解及使用示例詳解

    vue中v-mode詳解及使用示例詳解

    這篇文章主要介紹了vue中v-mode詳解以及具體的使用示例,在組件中使用?v-model?時(shí),需要定義model選項(xiàng),指定綁定的prop和事件,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2024-03-03
  • 詳解vue-cli + webpack 多頁(yè)面實(shí)例配置優(yōu)化方法

    詳解vue-cli + webpack 多頁(yè)面實(shí)例配置優(yōu)化方法

    本篇文章主要介紹了詳解vue-cli + webpack 多頁(yè)面實(shí)例配置優(yōu)化方法,具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-07-07
  • Vue用v-for給src屬性賦值的方法

    Vue用v-for給src屬性賦值的方法

    下面小編就為大家分享一篇Vue用v-for給src屬性賦值的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03
  • vue項(xiàng)目中解決 IOS + H5 滑動(dòng)邊界橡皮筋彈性效果(解決思路)

    vue項(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)目

    這篇文章主要介紹了如何讓別人訪問(wèn)本地運(yùn)行的vue項(xiàng)目,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • vue中使用mixins/extends傳入?yún)?shù)的方式

    vue中使用mixins/extends傳入?yún)?shù)的方式

    這篇文章主要介紹了vue中使用mixins/extends傳入?yún)?shù)的方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Vue+Element-ui彈窗?this.$alert?is?not?a?function問(wèn)題

    Vue+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-10
  • Vue腳手架的簡(jiǎn)單使用實(shí)例

    Vue腳手架的簡(jiǎn)單使用實(shí)例

    這篇文章主要介紹了Vue腳手架的簡(jiǎn)單使用實(shí)例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-07-07
  • Vue項(xiàng)目中v-bind動(dòng)態(tài)綁定src路徑不成功問(wèn)題及解決

    Vue項(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
  • vue內(nèi)置組件Transition的示例詳解

    vue內(nèi)置組件Transition的示例詳解

    這篇文章主要介紹了vue內(nèi)置組件Transition的詳解,簡(jiǎn)單地說(shuō),就是當(dāng)元素發(fā)生變化,比如消失、顯示時(shí),添加動(dòng)畫讓它更自然過(guò)渡,它是vue內(nèi)置組件,不需要引入注冊(cè)就可以直接使用,本文通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-09-09

最新評(píng)論