# Dialog 弹窗

弹窗组件,支持函数式调用

# 引入

import PressDialog from 'press-ui/press-dialog/press-dialog';

export default {
  components: {
    PressDialog,
  }
}

# 基本用法

示例

<press-dialog id="tip-match-comm-tips-dialog" />
import PressDialog from 'press-ui/press-dialog';

export default {
  methods: {
    showDialog() {
      PressDialog.show({
        title: '提示',
        content: '仅限队长报名,发给队长来报名吧!',
        confirmText: '确认',
        cancelText: '取消',
      }).then(() => {})
        .catch(() => {});
    },
  },
};

# 嵌入图片

export default {
  methods: {
    showDialog() {
      PressDialog.show({
        title: '提示',
        content: '仅限队长报名,发给队长来报名吧!',
        confirmText: '确认',
        cancelText: '取消',
        src: 'https://mike-1255355338.cos.ap-guangzhou.myqcloud.com/press/qrcode/qrcode-wx-mp.png',
        onLongPressImage: () => {
          console.log('长按图片')
        }
      }).then(() => {})
        .catch(() => {});
    }
  }
}

# 嵌入HTML内容

export default {
  methods: {
    showDialog() {
      PressDialog.show({
        title: '提示',
        htmlContent = '<div>自定义<span style="color: red;">内容</span></div>',
        confirmText: '确认',
        cancelText: '取消',
      }).then(() => {})
        .catch(() => {});
    }
  }
}

# 嵌入输入框并异步关闭

设置 showFieldtrue,可展示输入框。

可通过 onConfirmClick 进行输入内容的校验,返回falsePromise<false>则不会关闭。

export default {
  methods: {
    showDialog() {
      PressDialog.show({
        title: '提示',
        content: '',
        confirmText: '确认',
        cancelText: '取消',
        showField: true,
        fieldPlaceHolder:'随便输点什么吧',
        fieldValue: 'Press UI',
        canTouchRemove: false,
        onConfirmClick = (context) => {
          if (!context.inputValue) {
            this.onGTip('请输入内容');
            return false;
          }
          this.onGTip(`内容: ${context.inputValue}`);
          return true;
        };
      }).then(() => {})
        .catch(() => {});
    }
  }
}

# 组件调用

press-dialog支持组件调用,可以嵌入额外内容。

多例模式可以用组件调用方式,以及动态改变按钮文案,比如实现倒计时,也可以用组件模式。

<PressDialogComp
  title="标题"
  :show="show"
  content="Some fake news"
  @confirm="onConfirm"
/>
export default {
  data() {
    return {
      show: true,
    }
  },
  methods: {
    onConfirm() {
      this.show = false;
    },
  }
};

# 全局设置

可以通过 setDefaultOptions 进行全局默认选项的配置,比如设置通用的 selector

// #ifdef MP
PressDialog.setDefaultOptions({
  selector: (context) => {
    if (!context) return;

    const globalComponent = context.selectComponent('#global-component');
    const dialog = globalComponent?.$vm?.$refs?.pressDialog;
    if (dialog) return dialog;

    const instance = globalComponent?.selectComponent('#press-dialog');
    return instance;
  },
});
// #endif

# API

# 方法

方法名 参数 返回值 介绍
Dialog options Promise 展示弹窗
Dialog.show options Promise 展示消息确认弹窗
Dialog.setDefaultOptions options void 修改默认配置,对所有 Dialog 生效
Dialog.resetDefaultOptions - void 重置默认配置,对所有 Dialog 生效
Dialog.clear - void 关闭弹窗

# Props

参数 说明 类型 默认值
show 是否显示 boolean false
title 标题 string 温馨提示
content 内容 string -
html-content html内容 string -
src 图片地址 string -
confirm-text 确认按钮文案 string 确定
cancel-text 取消按钮文案 string -
z-index 层级 number 99
can-touch-remove 是否可以点击蒙层关闭 boolean true
dialog-type 弹窗类型,1为普通弹窗,2loading弹窗 number 1
use-scroll-view 是否使用scroll-view包裹 boolean false
on-click-cancel 点击取消的事件 function null
on-confirm-click 点击确认的事件 function null
on-click-image 点击图片的事件 function null
on-long-press-image 长按图片的事件 function null
show-field 是否显示输入框 boolean false
field-value 输入框内容 string -
field-placeHolder 输入框占位文字 string -

# 在线调试

横屏