vue可以使用模态框modal吗(vue基于Teleport实现Modal组件)
类别:编程学习 浏览量:2686
时间:2022-01-20 00:05:10 vue可以使用模态框modal吗
vue基于Teleport实现Modal组件目录
- 1.认识Teleport
- 2.Teleport的基本用法
- 3.第一步优化
- 4.第二步优化
- 5.实现Modal组件
像我们如果写Modal组件、Message组件、Loading组件这种全局式组件,没有Teleport的话,将它们引入一个.vue文件中,则他们的HTML结构会被添加到组件模板中,这是不够完美的。
- 没有Teleport
- 有Teleport
下面就实战介绍一下如何用Teleport开发Modal组件
2.Teleport的基本用法Teleport的写法十分简单,只需要用<Teleport></Teleport>将内容包裹,并用to指定将HTML挂到哪个父节点下,就可以啦。
<teleport to="#modal"> 内容 </teleport>
如果我们在代码中将Teleport要挂载的DOM写死,那么每创建一个全局式组件,就需要有一个DOM节点,会越来越多,并且一直存在,这样的写法不是很优雅。比较好的解决方案就是:
- 在创建组件的时候,动态创建一个dom节点document.createElement(),
- 并添加到body中,document.body.appendChild(),
- 在组件卸载的时候销毁这个dom document.body.removeChild(),
setup(){ const node = document.createElement('li') node.id = 'modal' document.body.appendChild(node) onUnmounted(() => { document.body.removeChild(node) }) }
如果我们后续还要添加Message组件,Loading组件等功能,同样要用到Teleport,在每一个组件内部都写这么一段代码,实在有点冗余,vue3使我们能够很方便的将逻辑功能提取出来,从而达到逻辑复用的目的。
我们在src-hooks文件夹下创建useDOMCreate.ts文件,来封装这一块逻辑
// hooks/useDOMCreate.ts import { onUnmounted } from 'vue' function useDOMCreate(nodeId:string):void { const node = document.createElement('li') node.id = nodeId document.body.appendChild(node) onUnmounted(() => { document.body.removeChild(node) }) } export default useDOMCreate
使用:
import useDOMCreate from '../hooks/useDOMCreate' setup(props, ctx) { useDOMCreate('modal') }
具体封装Modal组件的细节这里就不讲啦,也没有什么复杂的逻辑。直接上代码。
//Modal.vue <template> <teleport to="#modal"> <li class="modal d-block" tabindex="-1" v-if="isVisible"> <li class="modal-dialog"> <li class="modal-content"> <li class="modal-header"> <h5 class="modal-title">{{title}}</h5> <button type="button" class="close" data-dismiss="modal" aria-label="Close"> <span aria-hidden="true" @click="onClose">×</span> </button> </li> <li class="modal-body"> <slot></slot> </li> <li class="modal-footer"> <button type="button" class="btn btn-secondary" data-dismiss="modal" @click="onClose">取消</button> <button type="button" class="btn btn-primary" @click="onConfirm">确定</button> </li> </li> </li> </li> </teleport> </template> <script lang="ts"> import { defineComponent } from 'vue' import useDOMCreate from '../hooks/useDOMCreate' export default defineComponent({ name: 'Modal', emits: ['model-close', 'model-confirm'], props: { title: { type: String, default: '' }, isVisible: { type: Boolean, default: false } }, setup(props, ctx) { useDOMCreate('modal') const onClose = () => { ctx.emit('model-close') } const onConfirm = () => { ctx.emit('model-confirm') } return { onClose, onConfirm } } }) </script>
使用示例
<template> <li class="post-detail-page"> <button type="button" class="btn btn-danger" @click="handleDelete">删除</button> <modal title='是否确认删除?' :isVisible="modalVisible" @model-close="hanldeModalClose" @model-confirm="handleModalConfim"> <p>确认要删除这篇文章吗?</p> </modal> </li> </template> <script lang="ts"> import { defineComponent, ref } from 'vue' import Modal from '../components/Modal.vue' export default defineComponent({ name: 'post-detail', components: { Modal }, setup() { const modalVisible = ref(false) const handleDelete = () => { modalVisible.value = true } const hanldeModalClose = () => { modalVisible.value = false } const handleModalConfim = () => { modalVisible.value = false ... / /后续逻辑处理 } return { hanldeModalClose, handleModalConfim, handleDelete, modalVisible } } }) </script>
以上就是vue基于Teleport实现Modal组件的详细内容,更多关于vue Teleport实现Modal组件的资料请关注开心学习网其它相关文章!
您可能感兴趣
- vue滚动条下拉翻页(Vue中利用better-scroll组件实现横向滚动功能)
- vue 访问后台接口(vue轮询请求解决方案的完整实例)
- vue点击导航进行内容切换(vue实现顶部左右滑动导航)
- vue实现商品详情讲解(京东 Vue3 组件库支持小程序开发的详细流程)
- vue做个人页面(vue简易记事本开发详解)
- vue动态路由实现权限控制(vue2/vue3路由权限管理的方法实例)
- vue双向数据绑定js如何实现(纯JS如何实现vue.js下的双向绑定功能)
- vue十大基础知识(vue实战中的一些实用小魔法汇总)
- vue三种判断条件(Vue中插槽和过滤器的深入讲解)
- vue自定义组件修饰符(Vue自定义组件使用事件修饰符的踩坑记录)
- vuecli打包项目(使用vue-cli创建项目并webpack打包的操作方法)
- vue常用的指令和修饰符(Vue中 Vue.prototype使用详解)
- vuejs指令解析(Vue.js中的计算属性、监视属性与生命周期详解)
- vue滑动切换页面(vue实现点击翻转效果)
- vue 如何执行动态js(如何利用vue.js实现拖放功能)
- vue实现添加一段代码功能(Vue实现动态查询规则生成组件)
- 城市记忆之上海 最难忘的是老弄堂里的市井味道(城市记忆之上海)
- 太鸡贼了,这老小区轻松搞定了停车问题(这老小区轻松搞定了停车问题)
- 太鸡贼了,这老小区轻松搞定了停车问题(这老小区轻松搞定了停车问题)
- 节日我在岗|警景相融 平安相伴(节日我在岗警景相融)
- 战 疫 时刻 致敬每一位石化大学的 守护者(战疫时刻)
- 老弄堂里的市井味道(老弄堂里的市井味道)
热门推荐
- python贪吃蛇项目介绍(python简单贪吃蛇开发)
- python指定参数教程(详解Python传入参数的几种方法)
- nginx配置root后的路径打不开(详解nginx.conf 中 root 目录设置问题)
- 怎么在当前目录调用python库(Python父目录、子目录的相互调用方法)
- mysql乐观锁一定比悲观锁性能高(mysql居然还能实现分布式锁的方法)
- sql server2005如何配置(SQLServer2005创建定时作业任务)
- react的setstate第二个参数(示例详解react中useState的用法)
- python爬虫爬取知乎(详解用python写网络爬虫-爬取新浪微博评论)
- python多进程与多线程详解(Python线程之定位与销毁的实现)
- phpstudy最佳配置(phpstudy如何开启openSSL?)