JS常用方法集合

这篇文章提供了几个JavaScript函数,包括从URL获取查询参数的getQueryString,将金额数字转换成大写的digitUppercase,手机号码的基本验证validatorPhone,账号(仅限英文、数字、下划线)验证validatorAccount,以及一个用于日期格式化的timeFormat函数,这些函数涵盖了数据处理和验证的常见需求。
摘要由CSDN通过智能技术生成

1.获取链接上的参数

  getQueryString(name) {
      return (
        decodeURIComponent(
          (new RegExp("[?|&]" + name + "=" + "([^&;]+?)(&|#|;|$)").exec(
            location.href
          ) || [, ""])[1].replace(/\+/g, "%20")
        ) || null
      );
    },

2.金额变成大写

// 金额数字转大写
export const digitUppercase = (price) => {
    const fraction = ['角', '分'];
    const digit = ['零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖'];
    const unit = [
        ['元', '万', '亿'],
        ['', '拾', '佰', '仟']
    ];
    let num = Math.abs(price);
    let s = '';
    fraction.forEach((item, index) => {
        s += (digit[Math.floor(num * 10 * 10 ** index) % 10] + item).replace(/零./, '');
    });
    s = s || '整';
    num = Math.floor(num);
    for (let i = 0; i < unit[0].length && num > 0; i += 1) {
        let p = '';
        for (let j = 0; j < unit[1].length && num > 0; j += 1) {
            p = digit[num % 10] + unit[1][j] + p;
            num = Math.floor(num / 10);
        }
        s = p.replace(/(零.)*零$/, '').replace(/^$/, '零') + unit[0][i] + s;
    }

    return s
        .replace(/(零.)*零元/, '元')
        .replace(/(零.)+/g, '零')
        .replace(/^整$/, '零元整');
};

3.手机号基本验证

let validatorPhone = (rule, value, callback) => {
    if (!value) {
        return callback(new Error('手机号不能为空'));
    } else if (Array.from(value).length != 11) {
        return callback(new Error('请输入正确的手机号'));
    } else {
        [...value].map((item) => {
            if (item.charCodeAt() > 57 || item.charCodeAt() < 48) {
                return callback(new Error('请输入正确的手机号'));
            }
        });
        callback();
    }
};

export {
    validatorPhone,
}

4.账号基本验证(只包含英文、数字、下划线)

let validatorAccount = (rule, value, callback) => {
    let r1 = /^[A-Za-z0-9_]+$/;
    if (Array.from(value).length < 6) {
        return callback(new Error('账号不能少于6位'));
    } else if (value && !r1.test(value)) {
        return callback(new Error('账号只能包含英文、数字包括下划线'));
    } else {
        callback();
    }
};

export {
    validatorAccount
}

5.日期格式化

export function timeFormat(ts, delimiter = "-") {
    let time;
    if (ts) {
        time = new Date(ts);
    } else {
        time = new Date();
    }
    let y = time.getFullYear();
    let m = time.getMonth() + 1;
    let d = time.getDate();
    return y + delimiter + conventNumber(m) + delimiter + conventNumber(d);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值