当前位置: 首页 > news >正文

信誉好的邯郸网站建设东莞关键词排名seo

信誉好的邯郸网站建设,东莞关键词排名seo,如何注册www 网站,诸城哪里有做网站的一、基本使用场景 有时我们可能会遇到这样的场景:一个组件模板的一部分在逻辑上从属于该组件,但从整个应用视图的角度来看,它在 DOM 中应该被渲染在整个 Vue 应用外部的其他地方。 这类场景最常见的例子就是全屏的模态框。理想情况下&#…

一、基本使用场景

有时我们可能会遇到这样的场景:一个组件模板的一部分在逻辑上从属于该组件,但从整个应用视图的角度来看,它在 DOM 中应该被渲染在整个 Vue 应用外部的其他地方。

这类场景最常见的例子就是全屏的模态框。理想情况下,我们希望触发模态框的按钮和模态框本身是在同一个组件中,因为它们都与组件的开关状态有关。但这意味着该模态框将与按钮一起渲染在应用 DOM 结构里很深的地方。这会导致该模态框的 CSS 布局代码很难写。

试想下面这样的 HTML 结构:

<div class="outer"><h3>Tooltips with Vue 3 Teleport</h3><div><MyModal /></div>
</div>

接下来我们来看看 <MyModal> 的实现:

<script setup>import { ref } from 'vue'const open = ref(false)
</script><template><button @click="open = true">Open Modal</button><div v-if="open" class="modal"><p>Hello from the modal!</p><button @click="open = false">Close</button></div>
</template><style scoped>.modal {position: fixed;z-index: 999;top: 20%;left: 50%;width: 300px;margin-left: -150px;}
</style>

这个组件中有一个 <button> 按钮来触发打开模态框,和一个 class 名为 .modal<div>,它包含了模态框的内容和一个用来关闭的按钮。

当在初始 HTML 结构中使用这个组件时,会有一些潜在的问题:

  • position: fixed 能够相对于浏览器窗口放置有一个条件,那就是不能有任何祖先元素设置了 transformperspective 或者 filter 样式属性。也就是说如果我们想要用 CSS transform 为祖先节点 <div class="outer"> 设置动画,就会不小心破坏模态框的布局!
  • 这个模态框的 z-index 受限于它的容器元素。如果有其他元素与 <div class="outer"> 重叠并有更高的 z-index,则它会覆盖住我们的模态框。

<Teleport> 提供了一个更简单的方式来解决此类问题,让我们不需要再顾虑 DOM 结构的问题。让我们用 <Teleport> 改写一下 <MyModal>

<button @click="open = true">Open Modal</button>// 通过 to 属性指定将 Teleport 内容传送到的位置。to 的值可以是一个 CSS 选择器字符串,也可以是一个 DOM 元素对象。
<Teleport to="body"><div v-if="open" class="modal"><p>Hello from the modal!</p><button @click="open = false">Close</button></div>
</Teleport>

Teleport 是Vue 3.0新特性之一。

Teleport 是一种能够将我们的模板渲染至指定DOM节点,不受父级stylev-show等属性影响,但dataprop数据依旧能够共用的技术(保持逻辑上的父子关系)

<Teleport> 挂载时,传送的 to 目标必须已经存在于 DOM 中。理想情况下,这应该是整个 Vue 应用 DOM 树外部的一个元素。如果目标元素也是由 Vue 渲染的,你需要确保在挂载 <Teleport> 之前先挂载该元素。

二、动态控制 Teleport

在某些场景下可能需要视情况禁用 <Teleport>。举例来说,我们想要在桌面端将一个组件当做浮层来渲染,但在移动端则当作行内组件。我们可以通过对 <Teleport> 动态地传入一个 disabled prop 来处理这两种不同情况。

使用 disabled 设置为 true 则 to属性不生效, false 则生效

<script setup>import { ref } from "vue";let isMobile = ref(true)
</script>
<template><teleport :disabled="isMobile" to='body'><Mobile></Mobile></teleport>
</template>

这里的 isMobile 状态可以根据 CSS media query 的不同结果动态地更新。

三、多个 Teleport 共享目标

一个可重用的模态框组件可能同时存在多个实例。对于此类场景,多个 <Teleport> 组件可以将其内容挂载在同一个目标元素上,而顺序就是简单的顺次追加,后挂载的将排在目标元素下更后面的位置上。如下示例:

<Teleport to="#modals"><div>A</div>
</Teleport>
<Teleport to="#modals"><div>B</div>
</Teleport>

渲染结果为:

<div id="modals"><div>A</div><div>B</div>
</div>

四、同一个组件渲染到不同 Teleport 中

<Teleport to="modal1"><Loading></Loading>
</Teleport>
<Teleport to="modal2"><Loading></Loading>
</Teleport>

http://www.hrbkazy.com/news/54863.html

相关文章:

  • 哪些网站比较容易做免费网络营销软件
  • 企业网站建设的作用网站优化的方式有哪些
  • 专注东莞微信网站建设广点通广告投放平台登录
  • 公安备案网站热线百度seo服务公司
  • 番禺网站建设报价长春百度网站优化
  • 抖音信息流广告怎么投放优化科技
  • vs可以做网站吗交换链接适用于哪些网站
  • 成都 专业 网站建设视频号链接怎么获取
  • 成都网站建设创新互联友情链接例子
  • 惠州网站开发温州网站优化推广方案
  • 做优化网站多少钱长沙百度关键词搜索
  • 开发游戏app需要多少钱昆明百度推广优化
  • 东莞回收网站设计病毒式营销案例
  • 网站开发 绩效考核东莞seo技术
  • 做调查问卷赚钱网站国外百度图片搜索引擎入口
  • 做微信网站价格整站seo教程
  • dw 做简单静态网站百度投诉平台在哪里投诉
  • 网上企业名称预先核准系统石家庄seo外包公司
  • 深圳市龙岗区做网站的公司有没有好用的网站推荐
  • 怎样在网上建立平台优化营商环境建议
  • 网站设置搜索关键字2023年7月最新新闻摘抄
  • 网站做选择题怎么快速选择天津搜狗seo推广
  • 陕西网站建设推广网络推广优化方案
  • 合肥效果好的网站推广seo英文全称
  • 邯郸网站设计制作网站运营管理
  • 设计做图免费网站推广赚钱的平台
  • 做网站的点子windows优化大师的特点
  • 一家专门做瓷砖特卖的网站搜索引擎优化的内容包括
  • 给小公司做网站赚钱吗网上网络推广
  • 镇海企业建站天津外贸seo推广