SweetAlert2 - 漂亮可定制的 JavaScript 弹窗

https://sweetalert2.github.io/
https://github.com/sweetalert2/sweetalert2

安装:

bash 复制代码
npm install sweetalert2

封装:

javascript 复制代码
import Swal from 'sweetalert2/dist/sweetalert2.js'
import 'sweetalert2/src/sweetalert2.scss'

/**
 * 
 * @param {string} icon  - icon类型 success error warning info question
 * @param {string} title - 标题
 * @param {string} text  - 内容
 * 
 * @param {boolean} showConfirmButton  - 是否开启确认按钮
 * @param {boolean} showCancelButton   - 是否开启取消按钮
 * @param {boolean} showDenyButton     - 是否开启拒绝按钮
 * @param {string} confirmButtonText   - 确认按钮文本
 * @param {string} cancelButtonText    - 取消按钮文本
 * @param {string} denyButtonText      - 拒绝按钮文本
 * @param {string} confirmButtonColor  - 确认按钮颜色
 * @param {string} cancelButtonColor   - 取消按钮颜色
 * @param {string} denyButtonColor     - 拒绝按钮颜色
 * 
 * @param {string} imageUrl     - 
 * @param {string} imageHeight  - 
 * @param {string} imageAlt     - 
 * 
 * @param {number} timer        - 持续时间
 * @param {boolean} draggable   - 是否拖拽
 * @param {boolean} heightAuto  - 是否开启自动高度
 * 
 * @return {Object}
 */
export async function handleSwal({
  icon,
  title = '',
  text = '',
  // 
  showConfirmButton = true,
  showCancelButton = true,
  showDenyButton = false,
  confirmButtonText = "确认",
  cancelButtonText = `取消`,
  denyButtonText = `拒绝`,
  confirmButtonColor,
  cancelButtonColor,
  denyButtonColor,
  // 
  imageUrl,
  imageHeight,
  imageAlt,
  // 
  // footer
  //
  timer,
  draggable = false,
  heightAuto = false
} = {}) {
  const res = await Swal.fire({
    icon: icon || 'question',
    title,
    text,
    // 按钮
    showConfirmButton,
    showCancelButton,
    showDenyButton,
    confirmButtonText,
    cancelButtonText,
    denyButtonText,
    confirmButtonColor,
    cancelButtonColor,
    denyButtonColor,
    // 图片内容
    imageUrl,
    imageHeight,
    imageAlt,
    // 底部内容
    // footer,
    // 配置
    timer, // 持续时间
    draggable, // 是否拖动
    heightAuto // 是否自动高度
  })
  return res
}
相关推荐
背书包的甜瓜2 分钟前
使用sass 实现px转vh或vw,适配适老化时,在设计图字体大小的基础上,增加3px(可配置),
前端·css·sass
十五_在努力2 分钟前
参透 JavaScript —— 图解 Event Loop 事件循环
前端·javascript
十五_在努力9 分钟前
参透JavaScript —— 判断数据类型的四种方式
前端·javascript
依辰15 分钟前
小程序自动化构建与版本管理方案优化
前端·javascript·微信小程序
Geoffwo16 分钟前
取消echarts地图悬浮时默认黄色高亮
前端·javascript·echarts
我是谁谁17 分钟前
Canvas 高级应用与实战项目<3>
javascript·css·canvas
前端大卫24 分钟前
🔥 如何“为所欲为”地渲染页面:优雅拦截 Fetch 和 XMLHttpRequest!
前端·javascript
苏州第一深情24 分钟前
【vue+leaflet】自定义控件(五)
前端·javascript·vue.js
逾明25 分钟前
在项目中使用Volta控制node版本
前端·node.js
日升26 分钟前
Electron 开发:获取当前客户端真实 IP
前端·javascript·electron