element/examples/docs/message-box.md

7.5 KiB
Raw Blame History

基本用法

MessageBox 组件提供了四种不同的样式来替代浏览器提供的alert等功能:$msgbox$alert$confirm以及$prompt

在本页文档中一一介绍它们,首先看最简单的示例,我们使用$alert

:::demo 它接收了两个参数,messagetitle。值得一提的是,窗口被关闭后,它会返回一个Promise对象便于进行后续操作的处理。

<template>
  <el-button @click.native="open">打开 Alert</el-button>
</template>

<script>
  export default {
    methods: {
      open() {
        this.$alert('这是一段内容, 这是一段内容, 这是一段内容, 这是一段内容, 这是一段内容', '消息');
      }
    }
  }
</script>

:::

配置项

MessageBox 组件也拥有极高的定制性,我们可以传入options作为第三个参数,它是一个字面量对象。

:::demo 第二个参数title必须定义为String类型,如果是Object,会被理解为optionstype字段表明消息类型,可以为successerrorinfowarning,无效的设置将会被忽略。

<template>
  <el-button @click.native="open2">打开 alert</el-button>
</template>

<script>
  export default {
    methods: {
      open2() {
        this.$alert('操作失败, 请稍后重试', '提示', {
          type: 'error'
        });
      },
    }
  }
</script>

:::

下面是一个 confirm 框。

:::demo 在这里我们用了Promise来处理后续响应。

<template>
  <el-button @click.native="open3">打开 confirm</el-button>
</template>

<script>
  export default {
    methods: {
      open3() {
        this.$confirm('此操作将永久删除该文件, 是否继续?', '提示', {
          type: 'warning'
        }).then(() => {
          this.$notify({
            type: 'success',
            message: '删除成功!'
          });
        }).catch(() => {
          this.$notify({
            type: 'info',
            message: '已取消删除'
          });          
        });
      },
    }
  }
</script>

:::

Prompt 框功能强大,可以处理简单的输入。

:::demo 可以用inputPattern字段自己规定匹配模式,或者用inputValidator规定校验函数,可以返回BooleanStringBooleanfalse或字符串时均表示校验为通过,String相当于定义了inputErrorMessage字段。此外,可以用inputPlaceholder字段来定义输入框的占位符。

<template>
  <el-button @click.native="open4">打开 prompt</el-button>
</template>

<script>
  export default {
    methods: {
      open4() {
        this.$prompt('请输入邮箱', '提示', {
          inputPattern: /[\w!#$%&'*+/=?^_`{|}~-]+(?:\.[\w!#$%&'*+/=?^_`{|}~-]+)*@(?:[\w](?:[\w-]*[\w])?\.)+[\w](?:[\w-]*[\w])?/,
          inputErrorMessage: '邮箱格式不正确'
        }).then(value => {
          this.$notify({
            type: 'success',
            message: '你的邮箱是: ' + value
          });
        }).catch(() => {
          this.$notify({
            type: 'info',
            message: '取消输入'
          });       
        });
      }
    }
  }
</script>

:::

Msgbox 框是最基本的弹框,与 Alert 的区别在于 Alert 无法通过 ESC 和 点击框外关闭。

:::demo 使用了showCancelButton字段,用于显示取消按钮,同时使用cancelButtonClass可以自定义样式,cancelButtonText来自定义按钮文本Confirm 按钮也具有相同的字段,在文末的字段说明中有完整的字段列表。

<template>
  <el-button @click.native="open5">打开 Message Box</el-button>
</template>

<script>
  export default {
    methods: {
      open5() {
        this.$msgbox({
          title: '消息',
          message: '这是一段内容, 这是一段内容, 这是一段内容, 这是一段内容, 这是一段内容, 这是一段内容, 这是一段内容',
          showCancelButton: true
        }).then(action => {
          this.$notify({
            type: 'info',
            message: 'action: ' + action
          });
        });
      },
    }
  }
</script>

:::

全局方法

Element 为 Vue.prototype 添加了如下全局方法:$msgbox, $alert, $confirm 和 $prompt。因此在 vue instance 中可以采用本页面中的方式调用 MessageBox

单独引用

单独引入 MessageBox

import { MessageBox } from 'element-ui';

对应于上述四个全局方法的调用方法依次为MessageBox, MessageBox.alert, MessageBox.confirm 和 MessageBox.prompt。

Options

参数 说明 类型 可选值 默认值
title MessageBox标题 string
message MessageBox消息正文内容 string
type 消息类型,用于显示图标 string 'success', 'info', 'warning', 'error'
showCancelButton 是否显示取消按钮 boolean false以 confirm 和 prompt 方式调用时为 true
showConfirmButton 是否显示确定按钮 boolean true
cancelButtonText 取消按钮的文本内容 string '取消'
confirmButtonText 确定按钮的文本内容 string '确定'
cancelButtonClass 取消按钮的自定义类名 string
confirmButtonClass 确定按钮的自定义类名 string
showInput 是否显示输入框 boolean false以 prompt 方式调用时为 true
inputPlaceholder 输入框的占位符 string
inputPattern 输入框的校验表达式 regexp
inputValidator 输入框的校验函数。可以返回布尔值或字符串,若返回一个字符串, 则返回结果会被赋值给 inputErrorMessage function
inputErrorMessage 校验未通过时的提示文本 string '输入的数据不合法!'