# MessageBox 弹框
模拟系统的消息提示框而实现的一套模态对话框组件,用于消息提示、确认消息和提交内容。
TIP
从场景上说,MessageBox 的作用是美化系统自带的 alert
、confirm
和 prompt
,因此适合展示较为简单的内容。如果需要弹出较为复杂的内容,请使用 Dialog。
# 消息提示
移动端仅$confirm,$message与PC端一致,其它方式请参照底端移动端弹框用法
当用户进行操作时会被触发,该对话框中断用户操作,直到用户确认知晓后才可关闭。
# 确认消息
移动端仅$confirm,$message与PC端一致,其它方式请参照底端移动端弹框用法
提示用户确认其已经触发的动作,并询问是否进行此操作时会用到此对话框。
# 提交内容
移动端仅$confirm,$message与PC端一致,其它方式请参照底端移动端弹框用法
当用户进行操作时会被触发,中断用户操作,提示用户进行输入的对话框。
# 自定义
移动端仅$confirm,$message与PC端一致,其它方式请参照底端移动端弹框用法
可自定义配置不同内容。
TIP
弹出层的内容可以是 VNode
,所以我们能把一些自定义组件传入其中。每次弹出层打开后,Vue 会对新老 VNode
节点进行比对,然后将根据比较结果进行最小单位地修改视图。这也许会造成弹出层内容区域的组件没有重新渲染,例如 #8931 (opens new window)。当这类问题出现时,解决方案是给 VNode
加上一个不相同的 key,参考这里 (opens new window)。
# 使用 HTML 片段
移动端不支持
message
属性支持传入 HTML 片段。
WARNING
message
属性虽然支持传入 HTML 片段,但是在网站上动态渲染任意 HTML 是非常危险的,因为容易导致 XSS 攻击 (opens new window)。因此在 dangerouslyUseHTMLString
打开的情况下,请确保 message
的内容是可信的,永远不要将用户提交的内容赋值给 message
属性。
# 区分取消与关闭
有些场景下,点击取消按钮与点击关闭按钮有着不同的含义。
# 居中布局
内容支持居中布局
# 全局方法
移动端仅$confirm,$message与PC端一致,其它方式请参照底端移动端弹框用法
如果您完整引入了 FxUI,它会为 Vue.prototype 添加如下全局方法:$msgbox, $alert, $confirm 和 $prompt。因此在 Vue instance 中可以采用本页面中的方式调用 MessageBox
。调用参数为:
$msgbox(options)
$alert(message, title, options)
或$alert(message, options)
$confirm(message, title, options)
或$confirm(message, options)
$prompt(message, title, options)
或$prompt(message, options)
# 单独引用
移动端不支持
如果单独引入 MessageBox
:
import { MessageBox } from 'fx-ui';
那么对应于上述四个全局方法的调用方法依次为:MessageBox, MessageBox.alert, MessageBox.confirm 和 MessageBox.prompt,调用参数与全局方法相同。
# Options
参数 | 说明 | 类型 | 可选值 | 默认值 |
---|---|---|---|---|
title | MessageBox 标题 | string | — | — |
message | MessageBox 消息正文内容 | string / VNode | — | — |
dangerouslyUseHTMLString | 是否将 message 属性作为 HTML 片段处理 | boolean | — | false |
type | 消息类型,用于显示图标 | string | success / info / warning / error | — |
iconClass | 自定义图标的类名,会覆盖 type | string | — | — |
customClass | MessageBox 的自定义类名 | string | — | — |
callback | 若不使用 Promise,可以使用此参数指定 MessageBox 关闭后的回调 | function(action, instance),action 的值为'confirm', 'cancel'或'close', instance 为 MessageBox 实例,可以通过它访问实例上的属性和方法 | — | — |
showClose | MessageBox 是否显示右上角关闭按钮 | boolean | — | true |
beforeClose | MessageBox 关闭前的回调,会暂停实例的关闭 | function(action, instance, done),action 的值为'confirm', 'cancel'或'close';instance 为 MessageBox 实例,可以通过它访问实例上的属性和方法;done 用于关闭 MessageBox 实例 | — | — |
distinguishCancelAndClose | 是否将取消(点击取消按钮)与关闭(点击关闭按钮或遮罩层、按下 ESC 键)进行区分 | boolean | — | false |
lockScroll | 是否在 MessageBox 出现时将 body 滚动锁定 | boolean | — | true |
showCancelButton | 是否显示取消按钮 | boolean | — | false(以 confirm 和 prompt 方式调用时为 true) |
showConfirmButton | 是否显示确定按钮 | boolean | — | true |
cancelButtonText | 取消按钮的文本内容 | string | — | 取消 |
confirmButtonText | 确定按钮的文本内容 | string | — | 确定 |
cancelButtonClass | 取消按钮的自定义类名 | string | — | — |
confirmButtonClass | 确定按钮的自定义类名 | string | — | — |
closeOnClickModal | 是否可通过点击遮罩关闭 MessageBox | boolean | — | true(以 alert 方式调用时为 false) |
closeOnPressEscape | 是否可通过按下 ESC 键关闭 MessageBox | boolean | — | true(以 alert 方式调用时为 false) |
closeOnHashChange | 是否在 hashchange 时关闭 MessageBox | boolean | — | true |
showInput | 是否显示输入框 | boolean | — | false(以 prompt 方式调用时为 true) |
inputPlaceholder | 输入框的占位符 | string | — | — |
inputType | 输入框的类型 | string | — | text |
inputValue | 输入框的初始文本 | string | — | — |
inputPattern | 输入框的校验表达式 | regexp | — | — |
inputValidator | 输入框的校验函数。可以返回布尔值或字符串,若返回一个字符串, 则返回结果会被赋值给 inputErrorMessage | function | — | — |
inputErrorMessage | 校验未通过时的提示文本 | string | — | 输入的数据不合法! |
center | 是否居中布局 | boolean | — | false |
roundButton | 是否使用圆角按钮 | boolean | — | false |
# 移动端
# 使用指南
需要注意的是,使用js对象调起的实例是单例模式。
# 独立引入
可以通过调用
close
方法关闭对话框。
this.$dialog({
title: 'Alert',
message: '内容',
});
# Confirm 消息确认
this.$confirm('内容')
.then(() => {
// confirm
})
.catch(() => {
// cancel
});
;
# beforeClose
拦截器用法
this.$confirm({
title: 'Confirm',
message: '内容',
beforeClose: (action, close) => {
if (action === 'confirm') {
} else {
}
},
});
# API
option | description | type | acceptable values | default |
---|---|---|---|---|
title | 标题 | String | -- | |
message | 内容 | String | -- | |
className | dialog弹层的根节点class | String | -- | |
showConfirmButton | 是否展示确认按钮 | Boolean | true | |
showCancelButton | 是否展示取消按钮 | Boolean | false | |
confirmButtonText | 确认按钮文案 | String | 确认 | |
cancelButtonText | 取消按钮文案 | String | 取消 | |
showModal | 是否显示蒙层 | Boolean | true | |
closeOnClickModal | 点击蒙层时是否关闭 | Boolean | false | |
beforeClose | 关闭前的回调函数,action 的值为cancel /confirm ,调用 close() 即关闭,调用 close(false) 则不关闭 | (action: string, close: (doClose: boolean) => void) => void | -- |