# Modal 弹窗
对 antv 的 modal 组件进行封装,扩展拖拽,全屏,自适应高度等功能
代码路径 [src/components/Modal](https://github.com/jeecgboot/jeecgboot-vue3/tree/master/src/components/Modal)
[TOC]
## Usage
**由于弹窗内代码一般作为单文件组件存在,也推荐这样做,所以示例都为单文件组件形式**
TIP
注意`v-bind="$attrs"`记得写,用于将弹窗组件的`attribute`传入`BasicModal`组件
~~~
// Modal.vue
<template>
<BasicModal v-bind="$attrs" title="Modal Title" :helpMessage="['提示1', '提示2']">
Modal Info.
</BasicModal>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
import { BasicModal } from '/@/components/Modal';
export default defineComponent({
components: { BasicModal },
setup() {
return {};
},
});
</script>
~~~
**页面引用弹窗**
~~~
// Page.vue
<template>
<div class="px-10">
<Modal @register="register" />
</div>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
import { useModal } from '/@/components/Modal';
import Modal from './Modal.vue';
export default defineComponent({
components: { Modal },
setup() {
const [register, { openModal }] = useModal();
return {
register,
openModal,
};
},
});
</script>
~~~
## useModal
用于外部组件调用
**useModal**用于操作组件
~~~
const [register, { openModal, setModalProps }] = useModal();
~~~
**register**
register 用于注册`useModal`,如果需要使用`useModal`提供的 api,必须将`register`传入组件的`onRegister`。
原理其实很简单,就是 vue 的组件子传父通信,内部通过`emit("register",instance)`实现。
同时独立出去的组件需要将`attrs`绑定到`BasicModal`上面。
~~~
<template>
<BasicModal v-bind="$attrs"></BasicModal>
</template>
~~~
**openModal**
用于打开/关闭弹窗
~~~
// true/false: 打开关闭弹窗
// data: 传递到子组件的数据
openModal(true, data);
~~~
**closeModal**
用于关闭弹窗
~~~
closeModal();
~~~
**setModalProps**
用于更改 modal 的 props 参数因为 modal 内容独立成组件,如果在外部页面需要更改 props 可能比较麻烦,所以提供**setModalProps**方便更改内部 modal 的 props
[Props](https://vvbin.cn/doc-next/components/modal.html#Props)内容可以见下方
~~~
setModalProps(props);
~~~
## useModalInner
用于独立的 Modal 内部调用
### Usage
~~~
<template>
<BasicModal
v-bind="$attrs"
@register="register"
title="Modal Title"
:helpMessage="['提示1', '提示2']"
>
<a-button type="primary" @click="closeModal" class="mr-2">从内部关闭弹窗</a-button>
<a-button type="primary" @click="setModalProps">从内部修改title</a-button>
</BasicModal>
</template>
<script lang="ts">
import { defineComponent } from 'vue';
import { BasicModal, useModalInner } from '/@/components/Modal';
export default defineComponent({
components: { BasicModal },
setup() {
const [register, { closeModal, setModalProps }] = useModalInner();
return {
register,
closeModal,
setModalProps: () => {
setModalProps({ title: 'Modal New Title' });
},
};
},
});
</script>
~~~
**useModalInner**用于操作独立组件
~~~
const [register, { closeModal, setModalProps }] = useModalInner(callback);
~~~
**callback**
type:`(data:any)=>void`
回调函数用于接收 openModal 第二个参数传递的值
~~~
useModal((data: any) => {
console.log(data);
});
~~~
**closeModal**
用于关闭弹窗
~~~
closeModal();
~~~
**changeOkLoading**
用于修改确认按钮的 loading 状态
~~~
changeOkLoading(true);
~~~
**changeLoading**
用于修改 modal 的 loading 状态
~~~
// true or false
changeLoading(true);
~~~
**setModalProps**
用于更改 modal 的 props 参数因为 modal 内容独立成组件,如果在外部页面需要更改 props 可能比较麻烦,所以提供**setModalProps**方便更改内部 modal 的 props
[Props](https://vvbin.cn/doc-next/components/modal.html#Props)内容可以见下方
## Props
TIP
除以下参数外,组件库文档内的 props 也都支持,具体可以参考[antv modal](https://2x.antdv.com/components/modal-cn/#API)
| 属性 | 类型 | 默认值 | 可选值 | 说明 |
| --- | --- | --- | --- | --- |
| title | `string` | \- | \- | modal 标题 |
| height | `number` | \- | \- | 固定 modal 的高度 |
| minHeight | `number` | \- | \- | 设置 modal 的最小高度 |
| draggable | `boolean` | true | true/false | 是否开启拖拽 |
| useWrapper | `boolean` | true | true/false | 是否开启自适应高度,开启后会跟随屏幕变化自适应内容,并出现滚动条 |
| wrapperFooterOffset | `number` | 0 | \- | 开启是适应高度后,如果超过屏幕高度,底部和顶部会保持一样的间距,该参数可以用来缩小底部的间距 |
| canFullscreen | `boolean` | true | true/false | 是否可以进行全屏 |
| defaultFullscreen | `boolean` | false | true/false | 默认全屏 |
| loading | `boolean` | false | true/false | loading 状态 |
| loadingTip | `string` | \- | \- | loading 文本 |
| showCancelBtn | `boolean` | true | true/false | 显示关闭按钮 |
| showOkBtn | `boolean` | true | true/false | 显示确认按钮 |
| helpMessage | `string , string[]` | \- | \- | 标题右侧提示文本 |
| centered | `boolean` | false | true/false | 是否居中弹窗 |
| cancelText | `string` | '关闭' | \- | 关闭按钮文本 |
| okText | `string` | '保存' | \- | 确认按钮文本 |
| closeFunc | () => Promise<boolean> | 关闭函数 | \- | 关闭前执行,返回 true 则关闭,否则不关闭 |
## Events
| 事件 | 回调参数 | 说明 |
| --- | --- | --- |
| ok | `function(e)` | 点击确定回调 |
| cancel | `function(e)` | 点击取消回调 |
| visible-change | `(visible:boolean)=>{}` | 打开或者关闭触发 |
## Slots
| 名称 | 说明 |
| --- | --- |
| default | 默认区域 |
| footer | 底部区域(会替换掉默认的按钮) |
| insertFooter | 关闭按钮的左边(不使用footer插槽时有效) |
| centerFooter | 关闭按钮和确认按钮的中间(不使用footer插槽时有效) |
| appendFooter | 确认按钮的右边(不使用footer插槽时有效) |
- 项目介绍
- 常见问题
- 开发环境准备
- 环境准备
- 启动项目
- 切换Vue3路由
- 项目配置详细说明
- 上线部署
- 快速构建&部署
- Docker镜像启动
- 项目配置
- 菜单配置
- 菜单缓存
- 积木报表菜单配置
- 首页配置
- 国际化
- 菜单国际化
- 组件注册
- 项目规范
- 跨域处理
- 样式库
- 图标生成
- package依赖介绍
- 菜单TAB风格
- 备份文档
- 详细构建和配置
- 构建部署1.0
- 切换Mock接口
- 原生路由(作废)
- 原生菜单(作废)
- 页面开启缓存(作废)
- 环境准备1.0
- 数据 mock&联调
- UI组件
- Form 表单组件
- Table 表格
- Modal 弹窗
- Drawer 抽屉组件
- Icon 图标组件
- Button 按钮
- 更多基础组件
- JSelectUser选择用户 ✔
- JSelectPosition岗位选择 ✔
- JSelectDept部门选择 ✔
- JCheckbox ✔
- JImportModal 列表导入弹窗组件
- JInput特殊查询组件 ✔
- JPopup弹窗选择组件 ✔
- JTreeSelect树形下拉框 (异步加载) ✔
- JAreaSelect 省市县级联组件
- JDictSelectTag 字典标签 ✔
- JEllipsis 超长截取显示组件 ✔
- JUpload 上传组件 ✔
- JEasyCron 定时表达式选择组件 ✔
- JInputPopup 多行输入窗口组件 ✔
- JSwitch 开关选择组件 ✔
- JTreeDict 分类字典树形下拉组件 ✔
- JSelectInput 可输入下拉框 ✔
- JEditor 富文本编辑器 ✔
- JMarkdownEditor Markdown编辑器 ✔
- JSearchSelect 字典表的搜索组件 ✔
- JSelectUserByDept 根据部门选择用户 ✔
- JVxeTable
- 组件配置文档
- 自定义组件
- 封装自定义组件
- 自定义组件增强
- 多级联动配置
- 使用示例
- 常见问题解答
- JAreaLinkage 省市县联动组件 ✔
- JCategorySelect 分类字典树 ✔
- JImageUpload 图片上传 ✔
- JSelectMultiple 下拉多选 ✔
- JSelectRole 选择角色 ✔
- JFormContainer 表单组件禁用 ✔
- SuperQuery 高级查询
- UserSelect 高级用户选择组件
- Basic
- Page
- Authority
- PopConfirmButton
- CollapseContainer
- ScrollContainer
- LazyContainer
- CodeEditor
- JsonPreview
- CountDown
- ClickOutSide
- CountTo
- Cropper
- Description
- FlowChart
- Upload
- Tree
- Excel
- Qrcode
- Markdown
- Loading
- Tinymce
- Time
- StrengthMeter
- Verify
- Transition
- VirtualScroll
- ContextMenu
- Preview
- Loading
- 前端权限
- 表单权限
- 显隐控制 ✔
- 禁用控制 ✔
- 列表权限
- 按钮权限控制
- 列字段显隐控制
- 行编辑组件权限
- 显隐控制
- 禁用控制
- 代码生成
- Online在线代码生成
- GUI代码生成
- 代码生成模板介绍
- vue3和vue3Native详细说明
- 深入开发
- 定义Form新组件
- 自定义列表查询
- 自定义表单布局
- 开发笔记
- 组件权限控制
- 使用Antd Vue原生Form
- 自定义图表组件
- 自定义渲染函数
- 如何编写mock接口
- 缓存用法
- 精简版代码制作
- 微前端(qiankun)集成
- 前端小技巧
- 表单整体禁用
- 弹框内下拉框错位
- 界面如何设置响应式
- 抽屉(Drawer)宽度自适应
- 生成菜单脚本
- Online表单
- Online常见问题
- Online表单配置
- 配置参数说明
- 系统标准字段
- 表单类型-主子表|树表
- 自定义查询配置
- Online表单风格
- Online表单删除说明
- Online联合查询配置
- online表单视图功能说明
- Online表单开启评论
- Online表单控件介绍
- 常用基础控件
- 高级关联记录
- Online表单控件配置
- 基本配置
- 控件扩展配置
- 默认值表达式
- 自定义查询配置
- 字段href
- 默认值(填值规则)
- 导入导出自定义规则
- Online表单权限配置
- 字段权限配置与授权
- 按钮权限配置与授权
- 数据权限配置与授权
- 联合查询数据权限规则说明
- 在线增强
- 自定义按钮
- SQL增强
- JS增强
- 按钮触发JS增强
- 列表Api
- 列表操作列前置事件
- 表单Api
- beforeSubmit事件
- loaded事件
- 表单值改变事件【单表/主表】
- 表单值改变事件【从表】
- 表单值改变事件【从改主】
- 控制字段显示与隐藏
- js增强实现下拉联动
- js增强控制下拉树数据
- JS增强 触发弹窗
- JS增强 http请求
- JS增强 方法定义
- 对接表单设计器后需注意
- JAVA增强
- 快速开始
- Online java增强 导入
- Online java增强 导出
- Online java增强 查询
- Online Java增强 http-api
- 表单类
- 列表类
- 其他功能示例
- 导入数据库表支持排除表
- 通过字段Href实现三级联动
- excel数据导入支持校验
- Online报表
- Online报表配置
- 配置成菜单
- 其他功能
- 推送消息
- ISO 8601书写格式
- 系统消息跳转至详情表单
- 菜单【批量申请(自定义)】功能说明
- Online自动化测试
- online AI自动化测试数据制作
- Online AI自动化测试数据制作
- Online AI模型测试用例功能详情
- JAVA后台功能
- saas多租户切换
- 新功能实现saas租户隔离
- 第三方集成
- 敲敲云集成钉钉