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
}
相关推荐
旺仔Sec3 分钟前
2026年度河北省职业院校技能竞赛“Web技术”(高职组)赛项竞赛任务
运维·服务器·前端
用户4099322502124 分钟前
Vue的Class绑定对象语法如何让动态类名切换变得直观高效?
前端·ai编程·trae
瘦的可以下饭了22 分钟前
Day01-API
javascript
GIS之路34 分钟前
GIS 数据转换:GDAL 实现将 CSV 转换为 Shp 数据(一)
前端
Nan_Shu_61443 分钟前
学习:Vue (2)
javascript·vue.js·学习
武清伯MVP1 小时前
深入了解Canvas:HTML5时代的绘图利器(一)
前端·html5·canvas
一水鉴天1 小时前
整体设计 定稿 之24 dashboard.html 增加三层次动态记录体系仪表盘 之2 程序 (Q208 之1)
前端·html
_杨瀚博1 小时前
微信支付集成_JSAPI
前端
polaris_tl1 小时前
react beginwork
前端
亮子AI1 小时前
【css】列表的标号怎么实现居中对齐?
前端·css