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

牛商网网站后台百度写作助手

牛商网网站后台,百度写作助手,怎么免费推广自己的业务,手机网站建设公司服务Teleport Teleport 是一个内置组件#xff0c;它可以将一个组件内部的一部分模板“传送”到该组件的 DOM 结构外层的位置去。 基本用法 有时我们可能会遇到这样的场景#xff1a;一个组件模板的一部分在逻辑上从属于该组件#xff0c;但从整个应用视图的角度来看…Teleport Teleport 是一个内置组件它可以将一个组件内部的一部分模板“传送”到该组件的 DOM 结构外层的位置去。 基本用法 有时我们可能会遇到这样的场景一个组件模板的一部分在逻辑上从属于该组件但从整个应用视图的角度来看它在 DOM 中应该被渲染在整个 Vue 应用外部的其他地方。 这类场景最常见的例子就是全屏的模态框。理想情况下我们希望触发模态框的按钮和模态框本身是在同一个组件中因为它们都与组件的开关状态有关。但这意味着该模态框将与按钮一起渲染在应用 DOM 结构里很深的地方。这会导致该模态框的 CSS 布局代码很难写。 试想下面这样的 HTML 结构 div classouterh3Tooltips with Vue 3 Teleport/h3divMyModal //div /div接下来我们来看看 MyModal 的实现 script setup import { ref } from vueconst open  ref(false) /scripttemplatebutton clickopen  trueOpen Modal/buttondiv v-ifopen classmodalpHello from the modal!/pbutton clickopen  falseClose/button/div /templatestyle scoped .modal {position: fixed;z-index: 999;top: 20%;left: 50%;width: 300px;margin-left: -150px; } /style这个组件中有一个 button 按钮来触发打开模态框和一个 class 名为 .modal 的 div它包含了模态框的内容和一个用来关闭的按钮。 当在初始 HTML 结构中使用这个组件时会有一些潜在的问题 position: fixed 能够相对于浏览器窗口放置有一个条件那就是不能有任何祖先元素设置了 transform、perspective 或者 filter 样式属性。也就是说如果我们想要用 CSS transform 为祖先节点 div classouter 设置动画就会不小心破坏模态框的布局 这个模态框的 z-index 受限于它的容器元素。如果有其他元素与 div classouter 重叠并有更高的 z-index则它会覆盖住我们的模态框。 Teleport 提供了一个更简单的方式来解决此类问题让我们不需要再顾虑 DOM 结构的问题。让我们用 Teleport 改写一下 MyModal button clickopen  trueOpen Modal/buttonTeleport tobodydiv v-ifopen classmodalpHello from the modal!/pbutton clickopen  falseClose/button/div /TeleportTeleport 接收一个 to prop 来指定传送的目标。to 的值可以是一个 CSS 选择器字符串也可以是一个 DOM 元素对象。这段代码的作用就是告诉 Vue“把以下模板片段传送到 body 标签下”。 我们也可以将 Teleport 和 Transition 结合使用来创建一个带动画的模态框。 Teleport 挂载时传送的 to 目标必须已经存在于 DOM 中。理想情况下这应该是整个 Vue 应用 DOM 树外部的一个元素。如果目标元素也是由 Vue 渲染的你需要确保在挂载 Teleport 之前先挂载该元素。 我们也可以将 Teleport 和 Transition 结合使用来创建一个带动画的模态框。 // 模态组件 script setup const props  defineProps({show: Boolean }) /scripttemplateTransition namemodaldiv v-ifshow classmodal-maskdiv classmodal-containerdiv classmodal-headerslot nameheader默认头部/slot/divdiv classmodal-bodyslot namebody默认内容/slot/divdiv classmodal-footerslot namefooter默认底部/slot/divbutton classmodal-default-button click$emit(close)OK/button/div/div/Transition /templatestyle .... .... .... 样式太多省略了 看效果图即可 ... ... ... /style// 父级页面 script langts setup import { ref } from vueimport Com24 from /components/demo/Com24.vue const showModal  ref(false) /scripttemplatediv classcontainerbutton idshow-modal clickshowModal  true开启模态窗/buttonTeleport tobody!-- 使用这个 modal 组件传入 prop --Com24 :showshowModal closeshowModal  falsetemplate #headerh3自定义标题/h3/template/Com24/Teleport/div /templatestyle langscss scoped .container { } /style 搭配组件使用 Teleport 只改变了渲染的 DOM 结构它不会影响组件间的逻辑关系。也就是说如果 Teleport 包含了一个组件那么该组件始终和这个使用了 teleport 的组件保持逻辑上的父子关系。传入的 props 和触发的事件也会照常工作。 这也意味着来自父组件的注入也会按预期工作子组件将在 Vue Devtools 中嵌套在父级组件下面而不是放在实际内容移动到的地方。 禁用 Teleport 在某些场景下可能需要视情况禁用 Teleport。举例来说我们想要在桌面端将一个组件当做浮层来渲染但在移动端则当作行内组件。我们可以通过对 Teleport 动态地传入一个 disabled prop 来处理这两种不同情况。 Teleport :disabledisMobile... /Teleport这里的 isMobile 状态可以根据 CSS media query 的不同结果动态地更新。 多个 Teleport 共享目标 一个可重用的模态框组件可能同时存在多个实例。对于此类场景多个 Teleport 组件可以将其内容挂载在同一个目标元素上而顺序就是简单的顺次追加后挂载的将排在目标元素下更后面的位置上。 Teleport to#modalsdivA/div /Teleport Teleport to#modalsdivB/div /Teleport 渲染的结果为 div idmodalsdivA/divdivB/div /div
http://www.zqtcl.cn/news/828671/

相关文章:

  • 上海长宁网站建设公司python语言基础
  • 官方网站怎样做餐饮业手机php网站
  • 网站建设企业有哪些内容十九届六中全会
  • 如何管理手机网站首页怎么建设一个社交网站
  • 网站规则山东网站备案网站
  • 成都网站制作龙兵科技做网站原型图用什么软件
  • 鄂州网站网站建设做网站 用哪种
  • 医药公司网站建设厦门网站建设合同
  • 网站开发全程设计注册公司哪个网站
  • 广州大型网站设计公司网站总体设计怎么写
  • 福州网站制作工具搜索引擎营销的特点是什么
  • 安徽省建设干部网站新品网络推广
  • 做网站要实名吗怎样给一个公司做网站
  • 品牌官方网站建设大航母网站建设
  • 自己做音乐网站挣钱吗网站定制公司kinglink
  • 网站建设案例新闻随州程力网站建设
  • 国外网站平台龙岩天宫山缆车收费
  • 站长工具seo综合查询是什么湖北做网站
  • 青海网站建设价格建一个免费网站的流程
  • 网站备案中 解析地址asp.net企业网站框架
  • flash里鼠标可以跟随到网站上就不能跟随了蚌埠网站建设
  • 东莞茶山网站建设网络推广方案ppt
  • 不需要写代码的网站开发软件模板之家如何免费下载
  • 购物网站模板多媒体网站开发实验报告
  • 做网站上数字快速增加上海市建设部注册中心网站
  • 义乌市网站制作青岛建设银行银行招聘网站
  • 公司网站的留言板怎么做wordpress减肥网站采集规则
  • app软件下载站seo教程wordpress实现专题
  • 在哪里自己建设网站做网站后期需要什么费用
  • 宁波网站推广怎么做微信公众号如何运营与推广