溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Vue中如何使用Teleport組件

發(fā)布時間:2023-04-13 10:10:46 來源:億速云 閱讀:84 作者:iii 欄目:編程語言

這篇文章主要介紹“Vue中如何使用Teleport組件”,在日常操作中,相信很多人在Vue中如何使用Teleport組件問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Vue中如何使用Teleport組件”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

01-組件套組件層次結(jié)構(gòu)很深時

比如:現(xiàn)在有兩個組件,父組件,子組件,在后代組件內(nèi),添加一個按鈕,彈出一個模態(tài)框,讓它在頁面垂直水平居中顯示

如下所示,父組件如下所示App.vue

<template>
    <div class="App">
        我是父組件
        <Child />
    </div>
</template>
<script setup>
    import Child from "./Child.vue"
</script>
<style>
.App {
    width: 400px;
    height: 400px;
    background:red;
}
</style>

如下是Child組件,示例代碼如下所示Child.vue,我們需要在孫(后代)組件,添加一個按鈕,點擊按鈕,彈出一個彈框,水平垂直居中顯示在頁面中央

<template>
    <div class="child">
      <p>我是子組件</p>
        <button @click="isModel=true">打開模態(tài)框</button>
        <div class="mask-dialog" v-if="isModel">
             <div class="box">
                  <h3>我是標(biāo)題</h3>
                  <div>我是彈框內(nèi)容</div>
                  <div>
                      <button @click="isModel=false">關(guān)閉</button>
                  </div>
             </div>
        </div>
    </div>
</template>
<script setup>
import { ref } from "vue";
let isModel = ref(false);
</script>
<style>
.child {
    width: 300px;
    height:300px;
    background:green;
}
/**灰色遮罩層 */
  .mask-dialog {
    width: 100%;
    height:100%;
    position:absolute;
    left:0;
    top:0;
    background:rgba(0,0,0,0.5)
  }
  
  .box {
    width: 200px;
    height:200px;
    position:absolute;
    left:50%;
    top:50%;
    transform:translate(-50%,-50%);
    background:pink;
    text-align:center;
  }
</style>

上面的子組件中有一個button按鈕來觸發(fā)打開當(dāng)前組件的模態(tài)框,里面存在著控制彈框的顯示和隱藏的邏輯,當(dāng)嵌套的組件比較深,復(fù)雜時

如果父級元素存在定位,那在控制子元素的位置時,用csstransform或者position:absolute,參照對象的變更,會破壞布局結(jié)構(gòu),會出現(xiàn)一些css樣式

控制的問題,解決起來會非常的痛苦

那這個Teleport組件就是為了解決這類問題,可以將指定的DOM結(jié)構(gòu)片段,獨立于到組件外面去,不受當(dāng)前組件布局結(jié)構(gòu)的影響

經(jīng)過Teleport的修改后

<template>
    <div class="child">
      <p>我是子組件</p>
        <button @click="isModel=true">打開模態(tài)框</button>
        <Teleport to="body">
            <div class="mask-dialog" v-if="isModel">
                 <div class="box">
                      <h3>我是標(biāo)題1</h3>
                      <div>我是彈框內(nèi)容</div>
                      <div>
                          <button @click="isModel=false">關(guān)閉</button>
                      </div>
                 </div>
            </div>
        </Teleport>  
    </div>
</template>
<script setup>
import { ref } from "vue";
let isModel = ref(false);
</script>
<style>
.child {
    width: 300px;
    height:300px;
    background:green;
}
/**灰色遮罩層 */
  .mask-dialog {
    width: 100%;
    height:100%;
    position:absolute;
    left:0;
    top:0;
    background:rgba(0,0,0,0.5)
  }
  
  .box {
    width: 200px;
    height:200px;
    position:absolute;
    left:50%;
    top:50%;
    transform:translate(-50%,-50%);
    background:pink;
    text-align:center;
  }
</style>

<Teleport>接收一個 to prop 來指定傳送的目標(biāo)。to 的值可以是一個 CSS 選擇器字符串,或id,也可以是一個 DOM 元素對象。這段代碼的作用就是告訴 Vue把以下模板片段傳送到 body 標(biāo)簽下

<Teleport to="#some-id">html結(jié)構(gòu)代碼</Teleport>
<Teleport to=".some-class">html結(jié)構(gòu)代碼</Teleport>
<Teleport to="body">html結(jié)構(gòu)代碼</Teleport>
<Teleport to="html">html結(jié)構(gòu)代碼</Teleport>

02-Teleport組件

它是Vue官方提供的一個內(nèi)置組件,它可以將一個組件內(nèi)部的一部分模板“傳送”到該組件的 DOM 結(jié)構(gòu)外層的位置去 也就是一種能夠?qū)⑽覀兊慕M件html結(jié)構(gòu)移動到指定位置的技術(shù)

<teleport to="移動到指定的位置,可以是html,body,或id,class">
   里面是Html結(jié)構(gòu)模板內(nèi)容
</teleport>

注意

<Teleport> 掛載時,傳送的 to 目標(biāo)必須已經(jīng)存在于DOM中。理想情況下,這應(yīng)該是整個 Vue 應(yīng)用 DOM 樹外部的一個元素。如果目標(biāo)元素也是由 Vue 渲染的,你需要確保在掛載 <Teleport> 之前先掛載該元素

這個teleport將指定的模板html,放置到頁面當(dāng)中指定的位置處,它是有條件的,不是可以任意傳送的

在安裝組件之前,目標(biāo)元素必須存在,即,目標(biāo)不能由組件本身呈現(xiàn),理想情況下應(yīng)該位于整個Vue組件樹之外。

如下代碼是不行的

<template>
    <div>
        <Teleport to=".content">
            <div>我是頭部的內(nèi)容</div>
        </Teleport>
         
    </div>
    <div>
        底部內(nèi)容
        <div></div>
    </div>
</template>
<script setup>
</script>
<style>
h2 {
    color: red;
}
</style>

03-需要知道的

teleport只是改變了渲染的 DOM 結(jié)構(gòu),它不會影響組件間的邏輯關(guān)系。也就是說,如果 <Teleport> 包含了一個組件,那么該組件始終和這個使用了 <teleport> 的組件保持邏輯上的父子關(guān)系。傳入的 props 和觸發(fā)的事件也會照常工作。

這也意味著來自父組件的注入也會按預(yù)期工作,子組件將在 Vue Devtools 中嵌套在父級組件下面,而不是放在實際內(nèi)容移動到的地方

位置移動了,提現(xiàn)在結(jié)構(gòu)模板上,但是數(shù)據(jù)邏輯依舊存在關(guān)聯(lián)的

04-如何禁用 Teleport

在某些場景下可能需要視情況禁用 <Teleport>。舉例來說,我們想要在桌面端將一個組件當(dāng)做浮層來渲染,但在移動端則當(dāng)作行內(nèi)組件。我們可以通過對 <Teleport> 動態(tài)地傳入一個 disabled prop 來處理這兩種不同情況

<Teleport :disabled="isMobile">
  ...
</Teleport>

這里的 isMobile 狀態(tài)可以根據(jù) CSS media query 的不同結(jié)果動態(tài)地更新

05-多個 Teleport 共享目標(biāo)時

一個可重用的模態(tài)框組件可能同時存在多個實例。對于此類場景,多個 <Teleport> 組件可以將其內(nèi)容掛載在同一個目標(biāo)元素上,而順序就是簡單的順次追加,后掛載的將排在目標(biāo)元素下更后面的位置上

比如下面這樣的用例

<Teleport to=".content">
  <div>A</div>
</Teleport>
<Teleport to=".content">
  <div>B</div>
</Teleport>

渲染的結(jié)果為

<div class="content">
  <div>A</div>
  <div>B</div>
</div>

到此,關(guān)于“Vue中如何使用Teleport組件”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI