【微信小程序开发】常用方法封装工具类utils.js

news/2024/7/20 4:04:17 标签: 微信小程序, 小程序

一、背景

开发小程序时会普遍使用到的方法特别适合用来封装一个工具类,现在把我经常用到的一些方法分享出来,也希望大家一起来集思广益,完善这个工具类

二、代码

//模态框
function showModal(title, content, confirm, cancel) {
    uni.showModal({
        title: title,
        content: content,
        showCancel: true,
        success(res) {
            if (res.confirm) {
                confirm(confirm)
            } else if (res.cancel) {
                if (cancel) {
                    cancel(cancel)
                }
            }
        },
    })
}
//提示框
function showToast(title, icon, duration, success) {
    uni.showToast({
        title: title,
        icon: icon,
        duration: duration ? duration : 2000,
        mask: true,
        success: function (res) {
            if (success) {
                success(res)
            }
        },
        fail: function () { },
    })
}
//加载框
function showLoading(title) {
    if (title) {
        uni.showLoading({
            title: title,
            mask: true,
            success: () => { },
            fail: () => {
                uni.hideLoading()
            }
        })
    } else {
        uni.showLoading({
            title: '加载中...',
            mask: true,
            success: () => { },
            fail: () => {
                uni.hideLoading()
            }
        })
    }
}
//手机号脱敏
function formatterPhone(value) {
    var len = value.length;
    var xx = value.substring(3, len - 4);
    var values = value.replace(xx, "****");
    return values;
}
//身份证脱敏
function formatterIDCard(value) {
    var len = value.length;
    var xx = value.substring(5, len - 4);
    var values = value.replace(xx, "**********");
    return values;
}
//节流
function throttle(fn, interval) {
    var enterTime = 0; //触发的时间
    var gapTime = interval || 2000; //间隔时间,如果interval不传,则默认2000ms
    return function () {
        var context = this;
        var backTime = new Date(); //第一次函数return即触发的时间
        if (backTime - enterTime > gapTime) {
            fn.call(context, arguments);
            enterTime = backTime; //赋值给第一次触发的时间,这样就保存了第二次触发的时间
        }
    };
}
//防抖
function debounce(fn, interval) {
    var timer;
    var gapTime = interval || 2000; //间隔时间,如果interval不传,则默认2000ms
    return function () {
        clearTimeout(timer);
        var context = this;
        var args = arguments; //保存此处的arguments,因为setTimeout是全局的,arguments不是防抖函数需要的。
        timer = setTimeout(function () {
            fn.call(context, args);
        }, gapTime);
    };
}
//格式化时间 返回2024/03/02 14:23:32这种格式
function formatTime(date) {
    const year = date.getFullYear()
    const month = date.getMonth() + 1
    const day = date.getDate()
    const hour = date.getHours()
    const minute = date.getMinutes()
    const second = date.getSeconds()
    return `${[year, month, day].map(formatNumber).join('/')} ${[hour, minute, second].map(formatNumber).join(':')}`
}
function formatNumber(n) {
    n = n.toString()
    return n[1] ? n : `0${n}`
}
//字符串转数字,默认两位
function string2Number(str) {
    return Number.parseInt(str).toFixed(2);
}
//请求封装
function requestUrl(url, data, method) {
    let promise = new Promise((resolve, reject) => {
        uni.request({
            url: url,
            data: data,
            method: method,
            header: {
                'token': wx.getStorageSync('token')
            },
            success: res => {
                resolve(res.data);
            },
            fail: res => {
                reject(res.data);
            },
        })
    })
    return promise
}
module.exports = {
    throttle,
    debounce: debounce,
    showModal,
    showToast,
    showLoading,
    requestUrl,
    string2Number,
    formatTime,
    formatterPhone,
    formatterIDCard
};


http://www.niftyadmin.cn/n/5403705.html

相关文章

NLP - 共现矩阵、Glove、评估词向量、词义

Word2vec算法优化 J(θ): 损失函数 问题:进行每个梯度更新时,都必须遍历整个语料库,需要等待很长的时间,优化将非常缓慢。 解决:不用梯度下降法,用随机梯度下降法 (SGD)。 减少噪音&…

【计算机视觉】OpenCV3编程入门-笔记(一)

怀念毛星云大佬。。🕯️ 邂逅OpenCV OpenCV周边概念汄知 图像处现、计算机视觉与OpenCV 图像处理技术一般包括图像压缩,增强和复原,匹配、描述和识别3个部分,数字图像是指用工业相机、摄像机、扫描仪等设备经过拍摄得到的一个…

Java集合-Map接口

在Java中,Map接口表示键值对的集合,其中每个键都是唯一的,并且每个键映射到一个值。Map接口是集合框架中的一部分,位于java.util包中。它定义了一系列操作来管理键值对,例如添加键值对、删除键值对、获取键对应的值等。…

力扣爆刷第84天之hot100五连刷6-10

力扣爆刷第84天之hot100五连刷6-10 文章目录 力扣爆刷第84天之hot100五连刷6-10一、15. 三数之和二、42. 接雨水三、3. 无重复字符的最长子串四、438. 找到字符串中所有字母异位词五、560. 和为 K 的子数组 一、15. 三数之和 题目链接:https://leetcode.cn/problem…

Image Fusion via Vision-Language Model【文献阅读】

阅读目录 文献阅读AbstractIntroduction3. Method3.1. Problem Overview3.2. Fusion via Vision-Language Model 4. Vision-Language Fusion Datasets5. Experiment5.1Infrared and Visible Image Fusion 6. Conclusion个人总结 文献阅读 原文下载:https://arxiv.or…

跨站脚本攻击xss-labs(1-20)靶机练手

目录 一、跨站脚本攻击(XSS) 1.1 漏洞简介 1.2:类型 1.3 XSS危害 1.4XSS防御规则 二、环境搭建 三、xsst通关记录 Level 1:文本解析为 HTML Level 2:htmlspecialchars;input 标签 value 注入 定义和用法 字符过滤绕过 …

Visual Studio C++项目远程断点调试客户现场程序方法

前言 程序开发一个很常见的场景,就是程序在自己本地部署调试明明一点问题都没有,但是部署到客户现场就问题百出,要调试起来还很困难,在自己本地也没有条件复现,很多时候只能靠日志一点点排查和猜测,耗费大…

springboot233大学生就业需求分析系统

大学生就业需求分析系统设计与实现 摘 要 信息数据从传统到当代,是一直在变革当中,突如其来的互联网让传统的信息管理看到了革命性的曙光,因为传统信息管理从时效性,还是安全性,还是可操作性等各个方面来讲&#xff…