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

vue3新增Teleport的問(wèn)題

 更新時(shí)間:2022年08月16日 09:32:33   作者:前端精髓  
這篇文章主要介紹了vue3新增Teleport的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

vue3新增Teleport

在開(kāi)始介紹Teleport之前先了解一下React的Portals特性。

Portal 提供了一種將子節(jié)點(diǎn)渲染到存在于父組件以外的 DOM 節(jié)點(diǎn)的優(yōu)秀的方案。

ReactDOM.createPortal(child, container)

第一個(gè)參數(shù)(child)是任何可渲染的 React 子元素,例如一個(gè)元素,字符串或 fragment。第二個(gè)參數(shù)(container)是一個(gè) DOM 元素。

通常來(lái)講,當(dāng)你從組件的 render 方法返回一個(gè)元素時(shí),該元素將被掛載到 DOM 節(jié)點(diǎn)中離其最近的父節(jié)點(diǎn):

render() {
? // React 掛載了一個(gè)新的 div,并且把子元素渲染其中
? return (
? ? <div>
? ? ? {this.props.children}
? ? </div>
? );
}

然而,有時(shí)候?qū)⒆釉夭迦氲?DOM 節(jié)點(diǎn)中的不同位置也是有好處的:

render() {
? // React 并*沒(méi)有*創(chuàng)建一個(gè)新的 div。它只是把子元素渲染到 `domNode` 中。
? // `domNode` 是一個(gè)可以在任何位置的有效 DOM 節(jié)點(diǎn)。
? return ReactDOM.createPortal(
? ? this.props.children,
? ? domNode
? );
}

一個(gè) portal 的典型用例是當(dāng)父組件有 overflow: hidden 或 z-index 樣式時(shí),但你需要子組件能夠在視覺(jué)上“跳出”其容器。例如,對(duì)話框、懸浮卡以及提示框。常見(jiàn)的情況是創(chuàng)建一個(gè)包含全屏模式的組件。

對(duì)話框 position: absolute 的定位相對(duì)于父 div 作為參考。Teleport 提供了一種簡(jiǎn)單的方法,使我們可以控制要在DOM中哪個(gè)父對(duì)象下呈現(xiàn)HTML。

<teleport to="#modals">
? <div>A</div>
</teleport>
<teleport to="#modals">
? <div>B</div>
</teleport>
<!-- result-->
<div id="modals">
? <div>A</div>
? <div>B</div>
</div>

多個(gè) <teleport> 組件可以將其內(nèi)容添加到同一目標(biāo)元素。

vue3 Teleport和插件的認(rèn)識(shí)與了解

一、認(rèn)識(shí)Teleport

在組件化開(kāi)發(fā)中,我們封裝一個(gè)組件A,在另外一個(gè)組件B中使用

  • 那么組件A中template的元素,會(huì)被掛載到組件B中template的某個(gè)位置
  • 最終我們的應(yīng)用程序會(huì)形成一顆DOM樹(shù)結(jié)構(gòu)

但是某些情況下,我們希望組件不是掛載在這個(gè)組件樹(shù)上的,可能是移動(dòng)到Vue app之外的其他位置

  • 比如移動(dòng)到body元素上,或者我們有其他的div#app之外的元素上
  • 這個(gè)時(shí)候我們就可以通過(guò)teleport來(lái)完成

Teleport是什么呢?

  • 它是一個(gè)Vue提供的內(nèi)置組件,類似于react的Portals
  • teleport翻譯過(guò)來(lái)是心靈傳輸、遠(yuǎn)距離運(yùn)輸?shù)囊馑?/li>
  • 它有兩個(gè)屬性
  • to:指定將其中的內(nèi)容移動(dòng)到的目標(biāo)元素,可以使用選擇器
  • disabled:是否禁用 teleport 的功能

我們來(lái)看下面代碼的效果:

二、和組件結(jié)合使用

當(dāng)然,teleport也可以和組件結(jié)合一起來(lái)使用

我們可以在 teleport 中使用組件,并且也可以給他傳入一些數(shù)據(jù)

三、多個(gè)teleport

如果我們將多個(gè)teleport應(yīng)用到同一個(gè)目標(biāo)上(to的值相同),那么這些目標(biāo)會(huì)進(jìn)行合并

四、認(rèn)識(shí)Vue插件

通常我們向Vue全局添加一些功能時(shí),會(huì)采用插件的模式,它有兩種編寫方式

  • 對(duì)象類型:一個(gè)對(duì)象,但是必須包含一個(gè) install 的函數(shù),該函數(shù)會(huì)在安裝插件時(shí)執(zhí)行
  • 函數(shù)類型:一個(gè)function,這個(gè)函數(shù)會(huì)在安裝插件時(shí)自動(dòng)執(zhí)行

插件可以完成的功能沒(méi)有限制,比如下面的幾種都是可以的

  • 添加全局方法或者 property,通過(guò)把它們添加到 config.globalProperties 上實(shí)現(xiàn)
  • 添加全局資源:指令/過(guò)濾器/過(guò)渡等
  • 通過(guò)全局 mixin 來(lái)添加一些組件選項(xiàng)
  • 一個(gè)庫(kù),提供自己的 API,同時(shí)提供上面提到的一個(gè)或多個(gè)功能

五、插件的編寫方式

這里編寫兩個(gè)插件示例,看一下怎么寫和用

對(duì)象類型的寫法

函數(shù)類型的寫法

在main.js中通過(guò)use使用這兩個(gè)插件

然后就可以在全局使用$name屬性了

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。 

相關(guān)文章

  • Vue router傳遞參數(shù)并解決刷新頁(yè)面參數(shù)丟失問(wèn)題

    Vue router傳遞參數(shù)并解決刷新頁(yè)面參數(shù)丟失問(wèn)題

    這篇文章主要介紹了Vue router傳遞參數(shù)并解決刷新頁(yè)面參數(shù)丟失問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • Vue.js最佳實(shí)踐(五招助你成為vuejs大師)

    Vue.js最佳實(shí)踐(五招助你成為vuejs大師)

    這篇文章主要介紹了Vue.js最佳實(shí)踐,本文主要面向?qū)ο笫怯幸欢╲ue.js 編輯經(jīng)驗(yàn)的開(kāi)發(fā)者,需要的朋友可以參考下
    2018-05-05
  • 基于vue的tab-list類目切換商品列表組件的示例代碼

    基于vue的tab-list類目切換商品列表組件的示例代碼

    這篇文章主要介紹了基于vue的tab-list類目切換商品列表組件的示例代碼,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-02-02
  • Map.vue基于百度地圖組件重構(gòu)筆記分享

    Map.vue基于百度地圖組件重構(gòu)筆記分享

    這篇文章主要為大家分享了Map.vue基于百度地圖組件重構(gòu)筆記,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • Vue 無(wú)限滾動(dòng)加載指令實(shí)現(xiàn)方法

    Vue 無(wú)限滾動(dòng)加載指令實(shí)現(xiàn)方法

    這篇文章主要介紹了Vue 無(wú)限滾動(dòng)加載指令的實(shí)現(xiàn)代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下
    2019-05-05
  • vue實(shí)現(xiàn)導(dǎo)航收縮框

    vue實(shí)現(xiàn)導(dǎo)航收縮框

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)導(dǎo)航收縮框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • vue上傳圖片文件的多種實(shí)現(xiàn)方法

    vue上傳圖片文件的多種實(shí)現(xiàn)方法

    這篇文章主要給大家介紹了關(guān)于vue上傳圖片文件的相關(guān)資料,介紹了利用原始input標(biāo)簽form表單上傳、elementui自帶的el-upload上傳以及elementui實(shí)現(xiàn)一次性上傳多張圖片等方法,需要的朋友可以參考下
    2021-05-05
  • vue與django集成打包的實(shí)現(xiàn)方法

    vue與django集成打包的實(shí)現(xiàn)方法

    這篇文章主要介紹了vue與django集成打包的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • 基于Vue3文件拖拽上傳功能實(shí)現(xiàn)

    基于Vue3文件拖拽上傳功能實(shí)現(xiàn)

    這篇文章主要介紹了Vue3文件拖拽上傳功能,支持拖拽到此區(qū)域上傳,支持選擇多個(gè)文件/文件夾,代碼很簡(jiǎn)單,對(duì)vue3拖拽上傳功能感興趣的朋友一起看看吧
    2022-10-10
  • 在Vue項(xiàng)目中集成和使用Lottie動(dòng)畫庫(kù)的步驟詳解

    在Vue項(xiàng)目中集成和使用Lottie動(dòng)畫庫(kù)的步驟詳解

    Lottie 是一個(gè)由 Airbnb 開(kāi)源的動(dòng)畫庫(kù),它允許你在 Web、iOS、Android 等平臺(tái)上使用體積小、高性能的體驗(yàn)豐富的矢量動(dòng)畫,本文將詳細(xì)介紹在 Vue 項(xiàng)目中如何集成和使用 Lottie,文中有詳細(xì)的代碼講解,需要的朋友可以參考下
    2023-11-11

最新評(píng)論