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

詳解Vue3中Teleport的使用

 更新時間:2021年05月21日 10:54:56   作者:前端先鋒  
門戶(Portal)的概念是Vue3的新功能之一,也就是將模板 HTML 移至 DOM 的不同部分的方法。Portal 是 React 中的常見功能,Vue2 的 portal-vue  庫也提供了相似的功能。在 Vue3 中用 Teleport 對這個概念提供了原生支持。本文將介紹Teleport的相關(guān)用法

在本文中,我們將介紹:

  • Teleport 的目的
  • Teleport 的例子
  • 一些很有意思的代碼交互

Teleport 的目的

首先是什么時候以及使用這個 Teleport 功能。

在開發(fā)較大的 Vue 項目時應(yīng)該以可重用的邏輯去組織代碼。但是當(dāng)處理某些類型的組件(如模式、通知或工具提示)時,模板 HTML 的邏輯可能不會和我們希望渲染元素處于相同的文件中。

實際上在大多數(shù)情況下,與 Vue 的 DOM 完全分開處理相比,處理這些元素要容易得多。因為嵌套組件的位置、z-index 和樣式等這些東西,可能由于需要處理其所有父對象的作用域而變得棘手。

而這些正是 Teleport 的用武之地。我們可以在邏輯所在的組件中編寫模板代碼,因為這樣我們可以使用組件的數(shù)據(jù)或 props。

如果不用 Teleport,我們還必須擔(dān)心事件傳播會把邏輯從子組件傳遞給 DOM 樹。

Teleport 是怎樣工作的

假設(shè)有一些子組件,我們想在其中觸發(fā)彈出的通知。正如剛剛討論的那樣,如果將通知以完全獨(dú)立的 DOM 樹渲染,而不是 Vue 的根 #app 元素,會更加簡單。

首先編輯 index.html 并在 </body> 之前添加一個 <div>。

//index.html
<body>
   <div id="app"></div>
   <div id='portal-target'></div>
</body>

接下來創(chuàng)建觸發(fā)渲染通知的組件。

//VuePortals.vue
<template>
  <div class='portals'>
    <button @click='showNotification'> Trigger Notification! </button>
    <teleport to='#portal-target'>
      <div class='notification'>
        This is rendering outside of this child component!
      </div>
    </teleport>
  </div>
</template>

<script>
import { ref } from 'vue'
export default {
  setup () {
    const isOpen = ref(false)

    var closePopup

    const showNotification = () => {
      isOpen.value = true

      clearTimeout(closePopup)

      closePopup = setTimeout(() => {
        isOpen.value = false
      }, 2000)
    }

    return {
      isOpen,
      showNotification
    }
  }
}
</script>

<style scoped>
  .notification {
    font-family: myriad-pro, sans-serif;
    position: fixed;
    bottom: 20px;
    left: 20px;
    width: 300px;
    padding: 30px;
    background-color: #fff;
  }
</style>

在這代碼段中,按下按鈕時,將渲染通知 2 秒鐘。但是我們的主要目標(biāo)是用 Teleport 獲取通知并在 VUE 程序外部渲染。

如你所見,Teleport 有一個必填屬性:to

to 屬性使用有效的 DOM 查詢字符串,它可以是:

  • 元素的 ID
  • 元素的類
  • 數(shù)據(jù)選擇器
  • 響應(yīng)查詢字符串

由于我們在 #portal-target 中傳遞了代碼,所以 Vue 程序?qū)⒄业轿覀儼?index.html 中的 #portal-target div,它會傳送門戶中的所有代碼并將其渲染在該 div 中。

下面是結(jié)果:

檢查元素并查看 DOM,可以很清楚地了解都發(fā)生了什么。

我們可以使用 VuePortals 組建中的所有邏輯,但是需要告訴我們的項目渲染在其他地方的哪個模板代碼。

以上就是詳解Vue3中的Teleport的詳細(xì)內(nèi)容,更多關(guān)于Vue3 中的Teleport的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 實例講解Vue.js中router傳參

    實例講解Vue.js中router傳參

    本篇文章通過實例給大家分析了Vue.js中router傳參的相關(guān)知識點,對此有興趣的朋友參考學(xué)習(xí)下。
    2018-04-04
  • 記一次vue去除#問題處理經(jīng)過小結(jié)

    記一次vue去除#問題處理經(jīng)過小結(jié)

    這篇文章主要介紹了vue去除#問題處理經(jīng)過,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • vue條件渲染列表渲染原理示例詳解

    vue條件渲染列表渲染原理示例詳解

    這篇文章主要為大家介紹了vue條件渲染列表渲染原理示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • vue后臺返回格式為二進(jìn)制流進(jìn)行文件的下載方式

    vue后臺返回格式為二進(jìn)制流進(jìn)行文件的下載方式

    這篇文章主要介紹了vue后臺返回格式為二進(jìn)制流進(jìn)行文件的下載方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • Vue實現(xiàn)數(shù)據(jù)請求攔截

    Vue實現(xiàn)數(shù)據(jù)請求攔截

    這篇文章主要為大家詳細(xì)介紹了Vue實現(xiàn)數(shù)據(jù)請求攔截,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • 淺談vue3中effect與computed的親密關(guān)系

    淺談vue3中effect與computed的親密關(guān)系

    這篇文章主要介紹了淺談vue3中effect與computed的親密關(guān)系,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • 簡單學(xué)習(xí)5種處理Vue.js異常的方法

    簡單學(xué)習(xí)5種處理Vue.js異常的方法

    這篇文章主要介紹了簡單學(xué)習(xí)5種處理Vue.js異常的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,,需要的朋友可以參考下
    2019-06-06
  • 關(guān)于vue3?option?api新玩法分享

    關(guān)于vue3?option?api新玩法分享

    vue3新特性中最重要、內(nèi)容最多的組合式api,組合式api既可以解決之前vue2開發(fā)的痛點,又提升了性能,下面這篇文章主要給大家介紹了關(guān)于vue3?option?api新玩法的相關(guān)資料,需要的朋友可以參考下
    2022-06-06
  • vue開發(fā)設(shè)計分支切換與cleanup實例詳解

    vue開發(fā)設(shè)計分支切換與cleanup實例詳解

    這篇文章主要為大家介紹了vue開發(fā)設(shè)計分支切換與cleanup實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • vue源碼中的檢測方法的實現(xiàn)

    vue源碼中的檢測方法的實現(xiàn)

    這篇文章主要介紹了vue源碼中的檢測方法的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09

最新評論