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

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

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

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

文檔: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)

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

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

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

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

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

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

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

    vue項(xiàng)目中解決 IOS + H5 滑動邊界橡皮筋彈性效果(解決思路)

    最近遇到一個問題,我們在企業(yè)微信中的 H5 項(xiàng)目中需要用到table表格(支持懶加載 上劃加載數(shù)據(jù)),但是他們在鎖頭、鎖列的情況下,依舊會出現(xiàn)邊界橡皮筋效果,這篇文章主要介紹了vue項(xiàng)目中解決 IOS + H5 滑動邊界橡皮筋彈性效果,需要的朋友可以參考下
    2023-02-02
  • 如何讓別人訪問本地運(yùn)行的vue項(xiàng)目

    如何讓別人訪問本地運(yùn)行的vue項(xiàng)目

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

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

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

    Vue+Element-ui彈窗?this.$alert?is?not?a?function問題

    這篇文章主要介紹了Vue+Element-ui彈窗?this.$alert?is?not?a?function問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • Vue腳手架的簡單使用實(shí)例

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

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

    Vue項(xiàng)目中v-bind動態(tài)綁定src路徑不成功問題及解決

    這篇文章主要介紹了Vue項(xiàng)目中v-bind動態(tài)綁定src路徑不成功問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue內(nèi)置組件Transition的示例詳解

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

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

最新評論