新聞中心
前提
Vue鼓勵(lì)我們通過(guò)將UI和相關(guān)行為封裝到組件中來(lái)構(gòu)建UI。我們可以將它們嵌套在另一個(gè)內(nèi)部,來(lái)構(gòu)建一個(gè)組成應(yīng)用程序UI樹(shù)。

然而,有時(shí)組件模板的一部分邏輯上屬于該組件,而從技術(shù)角度來(lái)看,最好將模板的這一部分移動(dòng)到DOM中Vue app之外的其他位置。
Teleport提供了一種干凈的方法,允許我們控制在DOM中哪個(gè)父節(jié)點(diǎn)下渲染HTML,而不必求助于全局狀態(tài)或?qū)⑵洳鸱譃閮蓚€(gè)組件。
- app.component('modal-button', {
- template: `
- Open full screen modal! (With teleport!)
- I'm a teleported modal!
- (My parent is "body")
- Close
- `,
- data() {
- return {
- modalOpen: false
- }
- }
- })
使用
與Vue compoents一起使用
如果
- const app = Vue.createApp({
- template: `
Root instance
- `
- })
- app.component('parent-component', {
- template: `
This is a parent component
- `
- })
- app.component('child-component', {
- props: ['name'],
- template: `
Hello, {{ name }}- `
- })
在這種情況下,即使在不同地方渲染child-compoents,它仍將是parent-component的子集,并將從中接受name prop。
這也意味著來(lái)自父組件的注入按預(yù)期工作,并且子組件將嵌套在Vue Devtools中的父組件之下,部署放在實(shí)際內(nèi)容移動(dòng)到的位置。
在同一目標(biāo)上使用多個(gè)teleport
一個(gè)常見(jiàn)的用例場(chǎng)景是一個(gè)可重用的
A B A B
使用
to:String。需要prop,必須是有效的查詢選擇器或HTMLElement(如果在瀏覽器環(huán)境中使用)。指定將在其移動(dòng)
disabled: boolean。此可選屬性可用于禁用
值得注意的是,這將移動(dòng)實(shí)際的DOM節(jié)點(diǎn),而不是被銷(xiāo)毀和重新創(chuàng)建,而且它還將保持
任何組件實(shí)例的活動(dòng)狀態(tài)。所有有狀態(tài)的HTML元素(即播放的視頻)都將保持其狀態(tài)。
網(wǎng)頁(yè)名稱(chēng):Vue3值得注意的新特性之——teleport
本文網(wǎng)址:http://www.5511xx.com/article/coojdgj.html


咨詢
建站咨詢
