弹窗 - showModal

/**
* 封装 uni.showModal
* @param {Object|String} options 配置对象或提示内容
* @param {String} [options.title='提示'] 标题
* @param {String} options.content 提示内容
* @param {Boolean} [options.showCancel=true] 是否显示取消按钮
* @param {String} [options.confirmText='确定'] 确认按钮文字
* @param {String} [options.cancelText='取消'] 取消按钮文字
* @param {String} [options.confirmColor='#3CC51F'] 确认按钮颜色
* @param {String} [options.cancelColor='#999'] 取消按钮颜色
* @param {Function} [callback] 回调函数,接收 confirm 参数
* @return {Promise} 返回 Promise 对象
*/
export function showModal(options, callback) {
// 处理参数,支持直接传入字符串内容
if (typeof options === 'string') {
options = {
content: options
}
} // 默认配置
const defaultOptions = {
title: '提示',
showCancel: true,
confirmText: '确定',
cancelText: '取消',
confirmColor: '#3CC51F',
cancelColor: '#999'
} // 合并配置
const modalOptions = {
...defaultOptions,
...options
} // 返回 Promise
return new Promise((resolve, reject) => {
uni.showModal({
...modalOptions,
success: (res) => {
// 执行回调函数
if (typeof callback === 'function') {
callback(res.confirm)
}
// Promise 处理
if (res.confirm) {
resolve(res)
} else if (res.cancel) {
reject(res)
}
},
fail: (err) => {
// 执行回调函数
if (typeof callback === 'function') {
callback(false)
}
reject(err)
}
})
})
} // 导出快捷方法
export const modal = {
// 普通提示
alert(content, title = '提示') {
return showModal({
content,
title,
showCancel: false
})
}, // 确认对话框
confirm(content, title = '提示') {
return showModal({
content,
title
})
}, // 删除确认
deleteConfirm(content = '确定要删除吗?', title = '删除提示') {
return showModal({
content,
title,
confirmText: '删除',
confirmColor: '#DD524D'
})
}, // 错误提示
error(content, title = '哎呀,出现错误了') {
return showModal({
content,
title,
showCancel: false,
confirmText: '我知道了',
confirmColor: '#DD524D'
})
}
}

「Uniapp」一些常用方法的封装的更多相关文章

  1. 「 深入浅出 」集合List

    第一篇文章 「 深入浅出 」java集合Collection和Map 主要讲了对集合的整体介绍,本篇文章主要讲List相对于Collection新增的一些重要功能以及其重要子类ArrayList.Li ...

  2. JavaScript OOP 之「创建对象」

    工厂模式 工厂模式是软件工程领域一种广为人知的设计模式,这种模式抽象了创建具体对象的过程.工厂模式虽然解决了创建多个相似对象的问题,但却没有解决对象识别的问题. function createPers ...

  3. 一个「学渣」从零开始的Web前端自学之路

    从 13 年专科毕业开始,一路跌跌撞撞走了很多弯路,做过餐厅服务员,进过工厂干过流水线,做过客服,干过电话销售可以说经历相当的“丰富”. 最后的机缘巧合下,走上了前端开发之路,作为一个非计算机专业且低 ...

  4. LOJ2722 「NOI2018」情报中心

    「NOI2018」情报中心 题目描述 C 国和D 国近年来战火纷飞. 最近,C 国成功地渗透进入了D 国的一个城市.这个城市可以抽象成一张有$n$ 个节点,节点之间由$n - 1$ 条双向的边连接的无 ...

  5. 「Sqlserver」数据分析师有理由爱Sqlserver之二-像使用Excel一般地使用Sqlserver

    大家一谈数据库,就觉得非常高深莫测,深不见底,非凡人敢去触摸.但Excel的话,没人敢说自己不会使用吧(相反一大堆人的简历上写着精通OFFICE所有软件套件).换作其他非微软厂商的数据库,的确很容易产 ...

  6. 「 深入浅出 」集合Map

    系列文章: 「 深入浅出 」java集合Collection和Map 「 深入浅出 」集合List 「 深入浅出 」集合Set 前面已经介绍完了Collection接口下的集合实现类,今天我们来介绍M ...

  7. iOS 9,为前端世界都带来了些什么?「译」 - 高棋的博客

    2015 年 9 月,Apple 重磅发布了全新的 iPhone 6s/6s Plus.iPad Pro 与全新的操作系统 watchOS 2 与 tvOS 9(是的,这货居然是第 9 版),加上已经 ...

  8. SpringBoot图文教程10—模板导出|百万数据Excel导出|图片导出「easypoi」

    有天上飞的概念,就要有落地的实现 概念十遍不如代码一遍,朋友,希望你把文中所有的代码案例都敲一遍 先赞后看,养成习惯 SpringBoot 图文教程系列文章目录 SpringBoot图文教程1「概念+ ...

  9. SpringBoot图文教程14—SpringBoot集成EasyExcel「上」

    有天上飞的概念,就要有落地的实现 概念十遍不如代码一遍,朋友,希望你把文中所有的代码案例都敲一遍 先赞后看,养成习惯 SpringBoot 图文教程系列文章目录 SpringBoot图文教程1「概念+ ...

  10. 「MoreThanJava」Day2:变量、数据类型和运算符

    「MoreThanJava」 宣扬的是 「学习,不止 CODE」,本系列 Java 基础教程是自己在结合各方面的知识之后,对 Java 基础的一个总回顾,旨在 「帮助新朋友快速高质量的学习」. 当然 ...

随机推荐

  1. CentOS7安装图形界面模式

    0.9272019.03.24 15:17:05字数 865阅读 22,115 本人通过VMware14安装Centos7.6过程中出现蓝屏现象,最后发现是因为在系统安装图形界面过程中报错导致,所以决 ...

  2. pandas数据统一绘图风格配置

    在使用pandas的时候,经常会用到Dataframe或者Series的plot方法,该方法底层实际上调的还是matplotlib.pyplot的plot方法.因此,通过对pyplot模块的绘图全局参 ...

  3. 【Pandas】concat方法使用注意点

    使用pandas库的concat做数据拼接需要注意,应该先对原始数据设置列名,如果没有设置列名,在拼接时只会保留第一个文件的第一行(以列名形式),由于剩下的文件在读取时会自动将第一行作为列名,这样就会 ...

  4. study Rust-2【环境与配置,随机数】

    Rust教程资料很多.但是,这是教程学习资料感觉挺好!推荐给你https://doc.rust-lang.org/stable/book/ (简体中文译本)在线阅读 学习rust开始有点感觉了.美好的 ...

  5. sql server2005的阻塞和死锁

    检查死锁及阻塞也可参考: sys.sysprocesses 能显示会话进程有多少, 等待时间, open_tran有多少事务, 阻塞会话是多少. 整体内容更为详细. 关键字段说明: spid 会话ID ...

  6. SynchronousQueue底层实现原理剖

    一.SynchronousQueue底层实现原理剖 SynchronousQueue(同步移交队列),队列长度为0.作用就是一个线程往队列放数据的时候,必须等待另一个线程从队列中取走数据.同样,从队列 ...

  7. eolinker内置变量更新导致的脚本变化(适用于所有应用前置、后置变量的场景)

    内置变量变化情况内置变量变化情况(相关地址https://help.eolinker.com/#/tutorial/?groupID=c-579&productID=13) 通过下表可以了解内 ...

  8. 没几个人需要了解的JDK知识,我却花了3天时间研究

    目前国内发布自己JDK版本的几家公司: 腾讯和阿里是因为有Java应用和云业务,所以在优化发布自己的版本 华为也是因为Java应用和云业务,不过因为还有服务器业务,所以还有Java课题的跑分需求,如S ...

  9. TablesOfContents.Add 方法 (python3处理Word添加目录)

    TablesOfContents.Add 方法 (Word) 返回一 个 TableOfContents 对象,该对象代表添加到文档中的目录. 语法 表达式.Add (Range, UseHeadin ...

  10. Sentinel——控制台使用

    简介 官网:https://sentinelguard.io/ 随着微服务的流行,服务和服务之间的稳定性变得越来越重要.Sentinel 是面向分布式.多语言异构化服务架构的流量治理组件,主要以流量为 ...