我正在使用Vue 3的teleport將元素渲染到一個div中,它按預期工作。
Teleport會將項目新增到所選元素中,但不會取代div中的目前元素。
我如何設定teleport以取代div中的元素,類似於vue應用程式在掛載時替換錨點div內容的方式?
背景:出於SEO的原因,我需要佔位元素,直到應用程式渲染和傳送。
<!-- 应用程序外部的HTML --> <div> <div id="teleport-here">传送占位符...我希望这个被传送组件替换</div> <div id="app">当应用程序挂载时,这个占位符将被应用程序替换...</div> </div> <!-- 传送组件 --> <teleport to="#telport-here"> <div>传送内容...</div> </teleport>
P粉9039692312023-11-07 09:40:07
您需要有一些單獨的邏輯來在必要時刪除佔位符。
在setup
中將佔位符的內容設為空:
Vue.createApp({ setup() { const placeholder = document.getElementById('teleport-here'); placeholder.innerHTML = ''; } }).mount('#app');
<script src="https://unpkg.com/vue@next"></script> <div> <div id="teleport-here">Teleport placeholder... I want this to be replaced by the teleport component</div> <div id="app">This placeholder will be replaced with app when app mounts... <!-- teleport component --> <teleport to="#teleport-here"> <div>Teleport content...</div> </teleport> </div> </div>