2018-08-02 18:02:34 +08:00
..
2018-08-02 18:02:34 +08:00
2018-08-01 17:16:15 +08:00

Dialog 弹出框

使用指南

在 index.json 中引入组件

{
  "usingComponents": {
    "van-dialog": "path/to/vant-weapp/dist/dialog/index"
  }
}

在需要使用的页面里引入组件库模板和脚本

<van-dialog id="van-dialog-test"></van-dialog>
const Dialog = require('path/to/vant-weapp/dist/dialog/dialog');

Page({
  // ...
  // 可以在任意方法里直接调用,即可唤起
  handleClick() {
    Dialog({
      title: '',
      message: '',
      selector: '#van-dialog-test'
    }).then((res) => {
      console.log(res);
    })
  }
});

代码演示

按钮展示方式

按钮可以通过设置 buttonsShowVertical 来切换按钮纵向展示或者横向并排展示,方便各种场景下使用。

Dialog({
  message: '这是一个模态弹窗',
  buttonsShowVertical: true,
  showCancelButton: true
});

自定义展示按钮

dialog 支持自定义展示按钮。设置 buttons 数组即可实现。自定义按钮的点击后,都会在 resolve 状态中监听到。

Dialog({
  message: '这是一个模态弹窗',
  buttons: [{
    // 按钮文案
    text: '现金支付',
    // 按钮文字颜色
    color: 'red',
    // 按钮类型,用于在 then 中接受点击事件时,判断是哪一个按钮被点击
    type: 'cash'
  }, {
    text: '微信支付',
    color: '#3CC51F',
    type: 'wechat'
  }, {
    text: '取消',
    type: 'cancel'
  }]
}).then(({ type, hasOpenDataPromise, openDataPromise }) => {
  // type 可以用于判断具体是哪一个按钮被点击
  console.log('=== dialog with custom buttons ===', `type: ${type}`);

  // - 在使用自定义按钮的情况下,可以将按钮的 openType 设置为微信原生按钮支持的 open-type
  // - 如果设置的 openType 为 'getUserInfo', 'getPhoneNumber', 'openSetting' 其中之一
  //       就认为是需要返回相应的数据
  //       为了处理方便,增加 flag 值 hasOpenDataPromise表示是否有微信开放数据返回
  //       这时,通过利用 openDataPromise可以获取开放数据返回的具体信息
  if (hasOpenDataPromise) {
    openDataPromise.then((data) => {
      console.log('成功获取信息', data);
    }).catch((data) => {
      console.log('获取信息失败', data);
    });
  }
});

方法

方法名 参数 返回值 介绍
Dialog options 弹窗展示参数,具体见下方具体参数, pageCtx 页面上下文,可以不传,默认使用当前页面 - 展示弹窗
Dialog.close options 和弹窗展示参数一致,这里只需要 selector - 关闭弹窗

具体参数

参数 说明 类型 默认值 必须
message 弹窗内容 String - 必须
selector 显示弹窗对应组件节点的选择器 String - 必须
title 弹窗标题 String -
autoClose 点击按钮后是否自动关闭弹窗 Boolean true
buttonsShowVertical 按钮是否纵向展示 Boolean false
showConfirmButton 是否展示确认按钮 Boolean true
confirmButtonText 确认按钮文案 String 确定
confirmButtonColor 确认按钮文字颜色 String #3CC51F
showCancelButton 是否展示取消按钮 Boolean false
cancelButtonText 取消按钮文案 String 取消
cancelButtonColor 取消按钮文字颜色 String #333
buttons 自定义按钮列表,设置以后,以上关于 确认 和 取消 按钮的设置全部不生效。 Array -

buttons 数据格式

[{
  // 按钮文案
  text: '现金支付',
  // 按钮文字颜色
  color: 'red',
  // 按钮类型,用于在 then 中接受点击事件时,判断是哪一个按钮被点击
  type: 'cash'
}, {
  // 按钮文案
  text: '微信支付',
  // 按钮文字颜色
  color: '#3CC51F',
  // 按钮类型,用于在 then 中接受点击事件时,判断是哪一个按钮被点击
  type: 'wechat'
}, {
  // 按钮文案
  text: '取消',
  // 按钮类型,用于在 then 中接受点击事件时,判断是哪一个按钮被点击
  type: 'cancel'
}, {
  text: '获取用户信息',
  type: 'userInfo',
  // 利用 OpenType 设置微信按钮的开放能力
  // 设置对应的值以后,这个按钮就会具有调用微信原生按钮支持的开放能力
  openType: 'getUserInfo'
}]