位置: IT常识 - 正文

Vue3中 内置组件 Teleport 详解(vue的内置组件)

编辑:rootadmin
Vue3中 内置组件 Teleport 详解 1. 基本概念1.1 简单理解

推荐整理分享Vue3中 内置组件 Teleport 详解(vue的内置组件),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue自带的组件,vue内部组件,vue组件使用方法,vue组件使用方法,vue的内置组件,vue组件使用方法,vue的内置组件,vue3组件写法,内容如对您有帮助,希望把文章链接给更多的朋友!

不管是 Vue2 还是 Vue3 中都有内置组件的存在,如 component 内置组件、transition 内置组件等等。内置组件就是官方给我们封装的全局组件,我们直接拿来用就可以了。 在 Vue3 中新增了 Teleport 内置组件,先来看下官方文档是怎么解释的。

<Teleport> 是一个内置组件,它可以将一个组件内部的一部分模板“传送”到该组件的 DOM 结构外层的位置去。

通俗解释: teleport 是一个内置组件,我们都知道 HTML 是由层级关系的,Vue3 中的组件也是有层级关系的。 假如在父组件中引用了一个子组件,那么渲染成页面后这个子组件 HTML 也是必然被父组件 HTML 包含的。 但是如果把子组件放置到了 teleport 组件中,那么我们就可以指定该子组件渲染到父组件之外的其它 DOM 节点下,比如 body 或者其它的 DOM 等等。这就有点类似与“传送”了。

1.2 典型案例

我们使用 Vue 的 UI 组件库的时候,经常会用到模态框这个组件。如:使用 Element-plus 的模态框。

<template> <el-button @click="dialogVisible = true">打开弹窗</el-button> <el-dialog v-model="dialogVisible" append-to-body title="我是弹窗" width="30%"> </el-dialog></template><script>import { ref } from 'vue';export default { setup(){ const dialogVisible = ref(false); return { dialogVisible } } }</script>

上段代码中在 App.vue 组件里面引用了 Element-plus 的弹窗组件,并且添加了一个 append-to-body 属性。 可以看到虽然弹窗组件是写在 App.vue 组件里面的,但是渲染出来的结果却是弹窗组件属于 body 节点,这是因为利用了 Element-plus 中弹窗的 append-to-body 属性,我们把该属性去掉再看看什么结果:

可以看到弹窗组件又乖乖的跑到了 App.vue 组件下面。

Vue3中 内置组件 Teleport 详解(vue的内置组件)

为何要这样做? 很简单,假如有非常多的弹窗,那么如何管理它们的 z-index 呢,也就是同时弹窗时的层级关系,如果每个弹窗都在各自的父组件中,那么我们是没法控制的,所有有必要把它们都拧出来,放在同一个父元素下面,这样就可以方便的设置层级关系了。

这和 teleport 组件有什么关系吗?有很大的关系,上面弹窗的 append-to-body 属性效果是 Element 给我们做的,要是我们想自己实现这样的效果,该怎么办呢?我们就可以使用内置组件 teleport 了。

2. 基础使用2.1 传送 DOM 节点<template> <div class="app"> App组件 <Teleport to="body"> <div>我是被 teleport 包裹的元素</div> </Teleport> </div></template>

从上图可以看出,Teleport 包裹的元素虽然是属于 app.vue 组件,但是渲染过后它却被渲染在了 body 这个 dom 元素下面了。 这都得归功于 Teleport 得传送功能,它的用法很简单,语法代码如下: 其中 to 就是“传送”的目的地了,即需要把包裹的内容传送到何处去。

<Teleport to="body"></Teleport>to 允许接收值:期望接收一个 CSS 选择器字符串或者一个真实的 DOM 节点。提示:<Teleport> 挂载时,传送的 to 目标必须已经存在于 DOM 中。理想情况下,这应该是整个 Vue 应用 DOM 树外部的一个元素。如果目标元素也是由 Vue 渲染的,你需要确保在挂载 <Teleport> 之前先挂载该元素。2.2 传送组件

< Teleport > 只改变了渲染的 DOM 结构,它不会影响组件间的逻辑关系。 也就是说,如果 < Teleport > 包含了一个组件,那么该组件始终和这个使用了 < teleport > 的组件保持逻辑上的父子关系。传入的 props 和触发的事件也会照常工作。 这也意味着来自父组件的注入也会按预期工作,子组件将在 Vue Devtools 中嵌套在父级组件下面,而不是放在实际内容移动到的地方。

// 父组件<template> <div class="app"> <Teleport to="body"> <div>被 teleport 包裹的组件-- {{count}}</div> <ChildComponent v-model="count"/> </Teleport> </div></template><script>import { ref } from 'vue';import ChildComponent from '@/components/childComponent';export default { components:{ ChildComponent }, setup(){ const count = ref(100); return { count, } } }</script>// 子组件<template> 子组件:<input type="text" v-model.number="inputVal" @input="userInput"></template><script>import { ref, watch } from 'vue';export default { props:{ modelValue:{ default:0, } }, setup(props,{emit}) { const inputVal = ref(null); const userInput = () => { emit('update:modelValue', inputVal.value) }; watch(props,(newVal,oldVal) => { inputVal.value = props.modelValue; },{immediate:true}) return { userInput, inputVal, } },}</script>

2.3 禁用传送功能

在某些场景下可能需要视情况禁用 < Teleport >,我们可以通过对 < Teleport > 动态地传入一个 disabled prop 来处理这两种不同情况( disabled 属性接收一个 Boolean 值,true 代表不允许传送,false 代表传送)。

<template> <div class="app"> app组件 <Teleport to="body" :disabled="true"> <p>我是被 teleport 包裹的元素</p> <p>{{ message }}</p> </Teleport> </div></template><script>import { ref } from 'vue';export default { setup(){ const message = ref('我是在 App 组件内部'); return { message, } } }</script>

2.4 多个元素传送给一个节点

多个 < Teleport > 组件可以将其内容挂载在同一个目标元素上,而顺序就是简单的顺次追加,后挂载的将排在目标元素下更后面的位置上。

<!-- index.html --><body> <div id="app"></div> <div id="customDom"></div></body><template> app组件 <Teleport to="#customDom"> <p>我是被 teleport 包裹的一号元素</p> </Teleport> <Teleport to="#customDom"> <p>我是被 teleport 包裹的二号元素</p> </Teleport></template>

本文链接地址:https://www.jiuchutong.com/zhishi/299052.html 转载请保留说明!

上一篇:python爬取网站数据(含代码和讲解)(python爬取网站数据毕业论文)

下一篇:2023年前端开发趋势未来可期(2023年前端开发找工作好找吗)

  • 扫描件怎么弄(扫描件怎么弄免费)

    扫描件怎么弄(扫描件怎么弄免费)

  • ppt图片文字四周环绕怎么弄

    ppt图片文字四周环绕怎么弄

  • 北京通怎么查看电子居住证(北京通怎么查看居住证)

    北京通怎么查看电子居住证(北京通怎么查看居住证)

  • 华为手机字体颜色如何设置成黑色(华为手机字体颜色怎么设置成红色)

    华为手机字体颜色如何设置成黑色(华为手机字体颜色怎么设置成红色)

  • 微软surface book3什么时候上市(微软surface book3优缺点)

    微软surface book3什么时候上市(微软surface book3优缺点)

  • 注销淘宝账号后可以重新注册吗(注销淘宝账号后,电脑登录的淘宝账号还在线吗)

    注销淘宝账号后可以重新注册吗(注销淘宝账号后,电脑登录的淘宝账号还在线吗)

  • 手机突然视频打不开了(手机打视频突然没声音了怎么回事)

    手机突然视频打不开了(手机打视频突然没声音了怎么回事)

  • 京东商家不发货平台会怎么处理(京东商家不发货怎么申请赔付)

    京东商家不发货平台会怎么处理(京东商家不发货怎么申请赔付)

  • 一个进程被唤醒意味着什么(一个进程被唤醒,其状态变为( ))

    一个进程被唤醒意味着什么(一个进程被唤醒,其状态变为( ))

  • iphone a1699是什么版本(苹果a1699是什么版本多少钱)

    iphone a1699是什么版本(苹果a1699是什么版本多少钱)

  • 打印机不工作是什么原因(打印机不工作是墨盒的原因吗?)

    打印机不工作是什么原因(打印机不工作是墨盒的原因吗?)

  • 快手主要是干什么用的(快手是干啥的?里边赚钱吗?)

    快手主要是干什么用的(快手是干啥的?里边赚钱吗?)

  • mate30pro屏幕分辨率(华为mate30pro屏幕分辨)

    mate30pro屏幕分辨率(华为mate30pro屏幕分辨)

  • 微博邀请新人有奖励吗(微博有邀请新用户奖励吗)

    微博邀请新人有奖励吗(微博有邀请新用户奖励吗)

  • word文档行数怎么设置(word文档行数怎么增加?)

    word文档行数怎么设置(word文档行数怎么增加?)

  • praal00是什么型号(pra–al00x是什么手机)

    praal00是什么型号(pra–al00x是什么手机)

  • 华为mate30是否支持5g(华为mate30支持nfc吗)

    华为mate30是否支持5g(华为mate30支持nfc吗)

  • 夜光屏是什么(夜光屏是什么东西)

    夜光屏是什么(夜光屏是什么东西)

  • 苹果x日历不显示节假日(苹果x日历不显示父亲节)

    苹果x日历不显示节假日(苹果x日历不显示父亲节)

  • 全民歌房如何设置隐身(全民歌房如何设置一人一首歌)

    全民歌房如何设置隐身(全民歌房如何设置一人一首歌)

  • 荣耀8x使用技巧(荣耀8x使用技巧图解)

    荣耀8x使用技巧(荣耀8x使用技巧图解)

  • qq运动无法同步数据(qq运动无法同步怎么办)

    qq运动无法同步数据(qq运动无法同步怎么办)

  • 高级前端常见面试题合集(前端 高级)

    高级前端常见面试题合集(前端 高级)

  • Web项目【用户管理系统】完整版(web用户管理系统报告)

    Web项目【用户管理系统】完整版(web用户管理系统报告)

  • 电费发票隔月开如何做账
  • 税务行政处罚是指
  • 增值税应交税费科目
  • 需要进项税额转出的发票还用勾选吗
  • 坏账准备需要计提成本吗
  • 过路费按照什么缴纳增值税
  • 房地产投资
  • 人力资源交哪些税费
  • 收购发票能使用几次
  • 小规模增值税附加税税率
  • 发票专用章换了需要登记吗
  • 融资租赁会计核算的一般原则是什么
  • 企业纳税成本管理方案
  • 增值税进项税转出所得税调整吗
  • 多计提的应收账款如何调整
  • 事业单位的股东是什么
  • 实收资本未实缴到位,是否缴纳印花税
  • 当月忘记暂估怎么办
  • 小规模建筑业有增值税吗
  • 没有发票的管理费用汇算清缴的时候怎么调出来
  • 员工年终福利发什么
  • 增值税附加税计入什么会计科目
  • 金蝶财务软件录入凭证
  • 积分返现活动
  • 注册资金印花税什么时候开始交
  • 电子发票报销有什么用
  • 合伙企业年度汇缴申报
  • 劳务派遣公司开票几个点
  • 利息保障倍数能反映企业偿债能力吗
  • 没票的购进能入成本吗
  • 出租的设备
  • 发放股票股利的会计分录怎么写
  • 脑部病毒感染什么症状
  • 网吧登录qq安全吗
  • bios设置教程视频
  • 大白菜u盘启动后黑屏
  • 出租的土地
  • 劳务的完成程度可以采用如下方法确定
  • php投票代码
  • php程序开发范例宝典光盘
  • php函数传递参数方式
  • thinkphp5.0框架
  • 小微企业所得税税收优惠政策2023年
  • 上月开了红字发票当月如何申报
  • php封装数据库连接
  • 利润表利息费用包括哪些科目
  • 后端三件套
  • 个体工商户一年要交多少税
  • 工资的补贴是多少
  • 网上变更财务负责人新负责人要确认吗
  • 两免三减半取消了吗
  • 银行转账付款会计分录
  • 存货周转率是指企业某一会计
  • 出口货物做免税处理
  • 本年利润总额是什么
  • 劳务派遣人员的档案会保存在用人单位吗
  • 减免所得税额怎么做分录
  • 上市公司股票增发条件
  • 如何调整以前年度库存
  • 用人单位劳务派遣人员工资怎么做账
  • 增值税进项税额在借方还是贷方
  • 营业收入增长率分析
  • 关联企业有什么好处
  • 私企银行有哪几家
  • win7系统如何打开
  • Vista、XP、Windows7下非会员如何去除QQ2009的广告
  • 使用微软
  • mac文件权限
  • win10怎么预览
  • os x10.8.5
  • 安装完xp系统直接黑屏怎么办
  • win8 Could not load type System.ServiceModel.Activation.HttpModule 错误解决方案
  • cortana win10
  • 博主是re_mini_scene
  • Metaio in Unity3d 教程---Metaio扫描图片要求(Image Tracking)
  • python构造方法的参数
  • jquery.inarray
  • jquery ajax局部加载方法详解(实现代码)
  • 辽宁地方税务网站官网
  • 电脑上装什么软件开税票
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设