位置: 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年前端开发找工作好找吗)

  • OPPO手机通话怎么自动录音(oppo手机通话怎么设置)

    OPPO手机通话怎么自动录音(oppo手机通话怎么设置)

  • 微信拉黑换手机还在吗(微信拉黑换手机后还在黑名单吗)

    微信拉黑换手机还在吗(微信拉黑换手机后还在黑名单吗)

  • 如何定时关机(Win10如何定时关机)

    如何定时关机(Win10如何定时关机)

  • 小米手机的镜子在哪(小米手机的镜子功能怎样打开)

    小米手机的镜子在哪(小米手机的镜子功能怎样打开)

  • 抖音怎么添加文字滚动(抖音怎么添加文案和话题)

    抖音怎么添加文字滚动(抖音怎么添加文案和话题)

  • 苹果耳机一代一个可以用一个不能用(苹果耳机一代一边响一边不响)

    苹果耳机一代一个可以用一个不能用(苹果耳机一代一边响一边不响)

  • 在word文档中怎么在方框里面打勾(在word文档中怎么查找关键字)

    在word文档中怎么在方框里面打勾(在word文档中怎么查找关键字)

  • 软件产品具有哪些特性(软件产品有哪些类型)

    软件产品具有哪些特性(软件产品有哪些类型)

  • 华为p30网速慢怎么办(华为p30网速慢怎么回事)

    华为p30网速慢怎么办(华为p30网速慢怎么回事)

  • 抖音降权多少天恢复(抖音降权多少天可以恢复)

    抖音降权多少天恢复(抖音降权多少天可以恢复)

  • 怎么知道群里匿名的人是谁(怎么知道群里匿名的是谁)

    怎么知道群里匿名的人是谁(怎么知道群里匿名的是谁)

  • 移动iphone6可用电信卡吗(移动版iphone6可以用联通卡吗)

    移动iphone6可用电信卡吗(移动版iphone6可以用联通卡吗)

  • 网易云音乐音乐包下载能永久保存吗(网易云音乐音乐品味怎么删除)

    网易云音乐音乐包下载能永久保存吗(网易云音乐音乐品味怎么删除)

  • 电脑正在休眠怎么开机(电脑正在休眠怎么退出)

    电脑正在休眠怎么开机(电脑正在休眠怎么退出)

  • vivox27删除自定义铃声(vivox27手机怎么删除自定义铃声)

    vivox27删除自定义铃声(vivox27手机怎么删除自定义铃声)

  • 通常人们称计算机系统是指(人们常说的计算机一般是)

    通常人们称计算机系统是指(人们常说的计算机一般是)

  • 微信怎么看到是谁举报的我(微信怎么看到是谁发的消息)

    微信怎么看到是谁举报的我(微信怎么看到是谁发的消息)

  • 拼多多砍价第二天同一个人能砍吗(拼多多砍价第二轮金币)

    拼多多砍价第二天同一个人能砍吗(拼多多砍价第二轮金币)

  • 微博怎么屏蔽一个人不给他看(微博怎么屏蔽一个人不让他看到我发的东西)

    微博怎么屏蔽一个人不给他看(微博怎么屏蔽一个人不让他看到我发的东西)

  • 虎牙直播如何签约(虎牙直播如何签到领经验币)

    虎牙直播如何签约(虎牙直播如何签到领经验币)

  • iMessage提示对方尚未开通iMessage解决方法(给对方发短信显示imessage)

    iMessage提示对方尚未开通iMessage解决方法(给对方发短信显示imessage)

  • 所得税费用是什么要素
  • 国际税收协定是怎样避税的
  • 背书承兑分录
  • 清包工可以有一部分小料吗
  • 报表的应交税费都包含什么
  • 资产减值损失在利润表怎么填列
  • 工会经费计税基数包含支付职工的辞退福利
  • 本期进项税大于销项税
  • 管理费用会计科目代码是多少
  • 辅导期一般纳税人管理办法
  • 滞纳金可以个人承担吗
  • 收取返利发票怎么开具?
  • 纳税调整税收金额
  • 分公司和总公司的财务是分开的吗
  • 制造业贷款用途
  • 超市积分礼品
  • 兼职教师个人所得税起征点
  • 售后回租业务的会计分录
  • 普通的增值税发票可以查询到购买人的信息吗
  • 应交税费属于什么费用科目
  • 收回公司代垫职工款项怎么做凭证?
  • 支付工人保险费计入什么科目里
  • 有哪些凭证
  • 企业为员工缴纳社保可以抵税吗
  • 长期待摊费用摊销明细表
  • 简介linux系统中的10个常用命令及功能
  • php tr td
  • 小规模纳税人差额征税
  • PHP:pg_lo_read_all()的用法_PostgreSQL函数
  • 跨年收到退回增值税税款的账务处理
  • PHP:disk_total_space()的用法_Filesystem函数
  • 任意公积金可以不提取吗
  • 小企业会计准则财务报表至少包括
  • 个人开发微信支付接口
  • 包装物应交消费税
  • 用pullout造句
  • 增值税普通发票需要交税吗
  • 不同会计制度资产负债表金额不一样
  • 基础的数据类型
  • 净资产小于注册资本
  • 会计信息采集每年都要采集吗
  • 对公外汇汇款业务
  • 生产企业购进的生产原材料用来装修公司会计处理
  • 库存商品期末为负数
  • 小企业资产总额怎么计算
  • 资本溢价举例说明
  • 行政事业单位的营业执照叫什么
  • 行政拨付工会经费可以用于职工福利发放吗
  • 分公司开票总公司付款可以吗
  • 企业开了发票
  • 会计科目设置的相关注意事项
  • sql server 数据库介绍
  • mysql读写分离实现原理
  • win7系统激活不成功怎么办
  • 黑苹果驱动说明
  • warning bios upgrade
  • win10临时文件设置
  • 电脑怎么调win7系统
  • Mac如何开启sip
  • win7如何开启飞行模式
  • linux文件系统管理命令
  • windows7的电脑
  • linux windows转linux
  • 分布式队列秒杀活动
  • win10系统附件在哪里
  • opengl环境光
  • perl字符串替换 ~s
  • jQuery实现两个下拉列表关联
  • github比较火的项目
  • vue watch form
  • jQuery的Ajax用户认证和注册技术实例教程(附demo源码)
  • jquery中如何获取元素?
  • TFC360冯燃:手游市场细分领域新秀崛起
  • 新办企业税务登记后还需要办理哪些业务
  • 上季度报表错误怎样更正
  • 河北省国家税务总局云办税厅
  • 房产税可以抵扣增值税吗
  • 补发上个月的工资怎么做账
  • 重庆投诉平台电话
  • 山东国家税务局许本虎
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设