js--常用函数库_js--常用函数库


学习资源推荐

函数名 作用
trim 去除空格
turnCase 大小写转换-全大写,全小写,首字母大写
parseCase 大小写相互转换
checkPwdStrength 验证密码强度
hexColor 随机16进制颜色
randomCode 指定位数随机码
keywordsCount 关键词统计
caseFormat 短横,下划线与小驼峰的相互转化
dateFormat 时间格式化
reverse 逆序输出
onlyArray 数组去重
flat 数组扁平化
sort 数组排序
bubble_sort 冒泡排序
resort 数组错乱排序
totalArr 数组求和
mergeArr 数组合并
lastItem 获取数组最后一项
preventShake 防抖
throttle 节流
deepCopy 深拷贝
clearWebSite 让网页变得干净–调试时使用
delInvalidprops 去除对象或数组的无效属性
downloadByUrl 根据指定url下载文件
enterEvent 回车事件监听
pastTime 已过时间
isLegalEmail 邮箱校验
isLegalName 中文名校验–(2-6)位
isLegalIdCard 身份证校验
isLegalPhone 手机号码校验
jsonFormat 自定义缩进的JSON格式化

安装:npm i sparkle-blink

API

字符串常用函数

trim 去除空格

  • param1 string str 待处理字符串
  • param2 number type 去除空格类型 1-所有空格 2-前后空格 3-前空格 4-后空格 默认为1
  • return string str 处理后的字符串
   trim(' hello  world  ',1)//helloworld

turnCase 大小写转换

  • param1 string str 待转换的字符串
  • param2 number type 1-全大写 2-全小写 3-首字母大写
  • return string str 处理后的字符串
   turnCase('hello',1);//HELLO
   turnCase('hello',2);//hello
   turnCase('hello',3);//Hello

parseCase 大小写相互转换

  • param string str 待转换的字符串
  • return string result 处理后的字符串
   parseCase('hello');//HELLO
   parseCase('HELLo');//hellO

checkPwdStrength 密码强度判断

  • param string str 待转换的字符串
  • 低于6为强度为0,字母+1,数字+1,下划线+1,特殊字符!@#$%+1,最高为4
  • return number lv 密码强度等级
   checkPwdStrength('12345');//0
   checkPwdStrength('123456');//1
   checkPwdStrength('123456a');//2
   checkPwdStrength('123456a_');//3
   checkPwdStrength('123456a_#');//4
   checkPwdStrength('123456a_#$');//4

hexColor 随机16进制颜色

  • return string str 带#号的随机16进制颜色
   hexColor();//#2Ecc71

randomCode 指定位数随机码

  • param number count 随机码位数
  • return string str 指定位数随机码
   randomCode(6);//anfmk1

keywordsCount 关键词统计

  • param1 string text 进行统计的文本
  • param2 string keywords 进行统计的关键词
  • return number count 关键词出现次数
  • tip:param1 document.body.innerText–全文统计
   keywordsCount('富强民主文明和谐富强民主文明和谐','和谐');//2

caseFormat 短横,下划线与小驼峰的相互转化

  • param1 string str 待转换字符串
  • param2 string type '-'or ‘_’,默认为下划线
  • return string str 转换后字符串
   caseFormat('stuName','-');//stu-name
   caseFormat('stuName','_');//stu_name

caseFormat 短横,下划线与小驼峰的相互转化

  • 时间格式化 dateFormat 形如–“20190803 11:01:07”
  • param1 Date date 待格式化的时间
  • param2 number type 格式化范围 1-精确到月 2-精确到日 3-精确到分钟 4-精确到秒
  • return string time 格式化后的时间
    dateFormat(new Date(),1)//201908
    dateFormat(new Date(),2)//20190806
    dateFormat(new Date(),3)//20190806 09:22
    dateFormat(new Date(),4)//20190806 09:23:03

reverse 逆序输出

  • param string str 源字符串
  • return string result 逆序输出的字符串
    reverse('hello');//olleh

数组常用函数

onlyArray 数组去重

  • param Array arr 待去重的数组
  • return Array arr 去重后的数组
    onlyArray([1,2,1,1,2,3,3]);//[1,2,3]

flat 数组扁平化

  • param Array arr 待扁平化的数组
  • return Array arr 扁平化后的数组
    flat([1,[2,[3,4]]]);//[1,2,3,4]

sort 数组排序

  • param1 Array arr 待排序的数组
  • param2 number rule 排序规则 1-升序 0-降序,默认升序
  • return Array arr 排序后的数组
    sort([1,5,3],1);//[1,3,5]
    sort([1,5,3],0);//[5,3,1]

bubble_sort 冒泡排序

  • param1 Array arr 要进行排序的数组
  • param2 number rule 排序规则 1-升序 0-降序,默认升序
  • return Array arr 排序后的数组
    bubble_sort([1,5,3],1);//[1,3,5]
    bubble_sort([1,5,3],0);//[5,3,1]

resort 数组错乱排序

  • param Array arr 待排序的数组
  • return Array arr 排序后的数组
    resort([1,2,3,4,5,6]);//[2, 1, 5, 3, 4, 6]

totalArr 数组求和

  • param Array arr 待求和的数组
  • return Number num 求和结果
    totalArr([1,2,3]);//6

mergeArr 数组合并

  • param1 Array arr 待合并数组
  • …params Array arr 合并数组,可放置多个
  • return Array arr 合并后的数组
    mergeArr([],[1,2],[3]);//[1,2,3]

lastItem 获取数组最后一项

  • param Array arr 源数组
  • return <> item 数组最后一项
    lastItem([1,2,3]);//3

其他常用函数

preventShake 防抖

  • param function fn 要进行防抖的函数
    function fn(){};
    preventShake(fn);

throttle 节流

  • param function fn 要进行节流的函数
    function fn(){};
    throttle(fn);

deepCopy 深拷贝

  • param Object obj 要进行拷贝的对象
  • return Object obj 拷贝后的对象
   deepCopy({name:'tom',age:18});//{name:'tom',age:18}

clearWebSite 让网页变得干净

  • tip:本质是将html-body内容隐藏并清除控制台
   clearWebSite();

delInvalidprops 去除对象或数组的无效属性

  • param Object obj 待处理对象或数组
  • return <> obj 处理后的对象或数组
   delInvalidprops([undefined,null,'',1]);//[1]
   delInvalidprops({name:undefined,age:null,hobby:'',sex:'boy');//{sex: "boy"}

downloadByUrl 根据指定url下载文件

  • param1 string url 待下载文件url
  • param2 string name 指定下载文件的名称 --默认为’下载’
  • tip:html5新特性 --a 标签 download属性 部分浏览器不支持
   downloadByUrl('url','desc');

enterEvent 回车事件监听

  • param function fn 业务函数
   function fn(){console.log('hello')};
   enterEvent(fn);

pastTime 已过时间

  • param Date startTime 起始时间
  • return string 时间节点描述

    pastTime(new Date());//刚刚

jsonFormat 自定义缩进的JSON格式化

  • param1 Object/Array obj 待格式化的对象或数组
  • param2 number space 缩进数
  • return string jsonStr 格式化后的json字符串

    jsonFormat([{name:'tom',age:18},{name:'jack',age:20},{name:'merry',age:19}],4);
    /*"[
    {
        "name": "tom",
        "age": 18
    },
    {
        "name": "jack",
        "age": 20
    },
    {
        "name": "merry",
        "age": 19
    }
]"
*/

正则表达式

isLegalEmail 邮箱校验

  • param string email 待校验邮箱
  • return boolean 校验结果

  isLegalEmail(yourEmail);//true or false

isLegalName 中文名校验--(2-6)位

  • param string name 待校验中文名
  • return boolean 校验结果

  isLegalName(yourName);//true or false

isLegalIdCard 身份证校验

  • param string idCard 待校验身份证
  • return boolean 校验结果

  isLegalIdCard(yourIdCard);//true or false

isLegalPhone 手机号码校验

  • param string phone 待校验手机号码
  • return boolean 校验结果

  isLegalPhone(yourPhone);//true or false

函数库


/* 字符串常用函数--start*/

/**
 * trim 去除空格
 * param1  string str 待处理字符串
 * param2  number type 去除空格类型 1-所有空格  2-前后空格  3-前空格 4-后空格 默认为1
 * return  string str 处理后的字符串
 */
function trim(str, type = 1) {
    if (type && type !== 1 && type !== 2 && type !== 3 && type !== 4) return;
    switch (type) {
        case 1:
            return str.replace(/\s/g, "");
        case 2:
            return str.replace(/(^\s)|(\s*$)/g, "");
        case 3:
            return str.replace(/(^\s)/g, "");
        case 4:
            return str.replace(/(\s$)/g, "");
        default:
            return str;
    }
}



/**
 * 大小写转换
 * param1 string str 待转换的字符串
 * param2 number type 1-全大写 2-全小写 3-首字母大写 
 * return  string str 处理后的字符串
 */

function turnCase(str, type) {
    switch (type) {
        case 1:
            return str.toUpperCase()
        case 2:
            return str.toLowerCase();
        case 3:
            return str[0].toUpperCase() + str.substr(1).toLowerCase()
        default:
            return str;
    }
}

/**
 * 大小写相互转换
 * param string str 待转换的字符串
 * return  string result 处理后的字符串
 */


function parseCase(str) {
    let result = '';
    for (let i = 0; i < str.length; i++) {
        let temp = str.charAt(i);
        let code = temp.charCodeAt();
        if ('a' <= temp && temp <= 'z') {
            temp = String.fromCharCode(code - 32);
        } else if ('A' <= temp && temp <= 'Z') {
            temp = String.fromCharCode(code + 32);
        }

        result += temp;
    }
    return result;
}



/**
 * 密码强度判断 checkPwdStrength
 * param string str 待转换的字符串
 * 低于6为强度为0,字母+1,数字+1,下划线+1,特殊字符!@#$%+1,最高为4
 * return  number lv 密码强度等级
 */

function checkPwdStrength(password) {
    //定义一个变量存储密码强度等级,默认为0
    let lv = 0;
    if (password.match(/[a-z]/g)) { lv++; } //密码包含字母
    if (password.match(/[0-9]/g)) { lv++; } //密码包含数字
    if (password.match(/_/g)) { lv++; } //密码包含下划线
    if (password.match(/[!@#$%]/g)) { lv++; } //密码包含!@#$%任意特殊字符
    if (password.length < 6) { lv = 0; }
    if (lv > 4) { lv = 4; }

    return lv;
}

/**
 * 随机16进制颜色 hexColor
 * return  string str 带#号的随机16进制颜色
 */

function hexColor() {

    let str = '#';
    let arr = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 'A', 'B', 'C', 'D', 'E', 'F'];
    for (let i = 0; i < 6; i++) {
        let index = Number.parseInt(Math.random() * 16);
        str += arr[index]
    }
    return str;
}


/**
 * 指定位数随机码 randomCode
 * param number count 随机码位数
 * return  string str 指定位数随机码
 */

function randomCode(count) {

    let str = '';
    let number_arr = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
    let string_arr = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'g', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'];
    let arr = [...number_arr, ...string_arr];

    for (let i = 0; i < count; i++) {
        let index = Number.parseInt(Math.random() * arr.length);
        str += arr[index];
    }
    return str;
}


/**
 * 关键词统计:统计一段文字中指定文字出现次数 keywordsCount
 * param1 string text 进行统计的文本
 * param2 string keywords 进行统计的关键词
 * return number count 关键词出现次数
 * tip:param1 document.body.innerText--全文统计
 */

function keywordsCount(text, keywords) {
    return text.split(keywords).length - 1
}


/**
 *  短横,下划线与小驼峰的相互转化 caseFormat
 *  param1 string str 待转换字符串
 *  param2 string type '-'or '_',默认为下划线
 *  return string str 转换后字符串
 */

function caseFormat(str, type = '_') {

    if (type && type !== '-' && type !== '_') return;
    let result = '';
    if (str.includes(type)) {
        let arr = str.split(type);
        result = arr[0]
        for (let i = 0; i < arr.length - 1; i++) {
            result += arr[i + 1][0].toUpperCase() + arr[i + 1].substr(1).toLowerCase()
        }
    } else {
        result = str.replace(/[A-Z]/g, function (match) {
            return type + match.toLowerCase();
        });

    }

    return result;
}




/**
 * 时间格式化 dateFormat  形如--"20190803 11:01:07"
 * param1 Date date 待格式化的时间
 * param2 number type 格式化范围 1-精确到月 2-精确到日 3-精确到分钟 4-精确到秒
 * return string time 格式化后的时间
 */

function dateFormat(date, type = 4) {
    if (type && type !== 1 && type !== 2 && type !== 3 && type !== 4) return;
    let y = date.getFullYear().toString();
    let m = (date.getMonth() + 1).toString().padStart(2, '0');
    let d = date.getDate().toString().padStart(2, '0');
    let h = date.getHours().toString().padStart(2, '0');
    let M = date.getMinutes().toString().padStart(2, '0');
    let s = date.getSeconds().toString().padStart(2, '0');
    if (type === 1) return y + m;
    if (type === 2) return y + m + d;
    if (type === 3) return y + m + d + " " + h + ":" + M;
    if (type === 4) return y + m + d + " " + h + ":" + M + ":" + s;

}

/**
 * 逆序输出 reverse 
 * param string str 源字符串
 * return string result 逆序输出的字符串
 */

function reverse(str) {
    let result = '';
    for (let i = str.length - 1; i >= 0; i--) {
        result += str[i];
    }
    return result;
};





/* 字符串常用函数--end*/



/* 数组常用函数--start*/

/**
 * 数组去重 onlyArray  
 * param1 Array arr 待去重的数组
 * return Array arr 去重后的数组
 */

function onlyArray(arr) {
    if (!Array.isArray(arr)) return;
    return Array.from(new Set([...arr]))
}

/**
 * 数组扁平化 flat  
 * param1 Array arr 待扁平化的数组
 * return Array arr 扁平化后的数组
 */

function flat(arr) {
    if (!Array.isArray(arr)) return;
    return arr.reduce((initValue, cur) => {
        return initValue.concat(Array.isArray(cur) ? flat(cur) : cur)
    }, [])
}


/**
 * 数组排序 sort  
 * param1 Array arr 待排序的数组
 * param2 number rule  排序规则 1-升序 0-降序,默认升序
 * return Array arr 排序后的数组
 */

function sort(arr, rule = 1) {
    if (!Array.isArray(arr)) return;
    if (rule && rule !== 1 && rule !== 0) return;
    return rule === 1 ? arr.sort((a, b) => a - b) : arr.sort((a, b) => b - a)

}

/**
 * 冒泡排序 bubble_sort  
 * param1 Array arr 要进行排序的数组
 * param2 number rule 排序规则 1-升序 0-降序,默认升序
 * return Array arr 排序后的数组
 */

function bubble_sort(arr, rule = 1) {
    if (!Array.isArray(arr)) return;
    if (rule && rule !== 1 && rule !== 0) return;
    for (let i = 0; i < arr.length - 1; i++) {
        for (let j = 0; j < arr.length - 1 - i; j++) {

            let expression1 = arr[j] > arr[j + 1]
            let expression2 = arr[j] < arr[j + 1]

            if (rule === 1 ? expression1 : expression2) {
                let temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }

        }
    }
    return arr;
}

/**
 * 数组错乱排序 resort  
 * param1 Array arr 待排序的数组
 * return Array arr 排序后的数组
 */


function resort(arr) {
    if (!Array.isArray(arr)) return;
    return arr.sort(function () {
        return Math.random() - 0.5
    });
}

/**
 * 数组求和 totalArr  
 * param1 Array arr 待求和的数组
 * return Array arr 求和后的数组
 */

function totalArr(arr) {
    if (!Array.isArray(arr)) return;
    return arr.reduce(function (pre, cur) {
        return pre + cur
    })
}

/**
 * 数组合并 mergeArr  
 * param1 Array arr 待合并数组
 * ...params Array arr 合并数组,可放置多个
 * return Array arr 合并后的数组
 */

function mergeArr(arr, ...everyArr) {
    if (!Array.isArray(arr)) return;
    return arr.concat(...everyArr)

}

/**
 * 获取数组最后一项 lastItem 
 * param Array arr 源数组
 * return <> item 数组最后一项
 */

function lastItem(arr) {
    if (!Array.isArray(arr)) return;
    return arr[arr.length - 1]

}





/* 数组常用函数--end*/




/* 其他常用函数--start*/


/**
 * 防抖 preventShake  
 * param function fn 要进行防抖的函数
 */

const preventShake = (fn) => {
    let timer = null; // 创建定时器id
    return () => {
        clearTimeout(timer); //事件频繁触发,清除之前定时器 
        timer = setTimeout(() => { // 创建新定时器,保证限定时间间隔fn只执行一次
            fn();
        }, 500);
    };
}

/**
 * 节流 throttle  
 * param function fn 要进行节流的函数
 */

const throttle = (fn) => {
    let lock = true; // 函数外设置状态锁,默认开启
    return () => {
        if (!lock) return; // 在函数开头判断标记是否为true,不为true则return,阻止后续程序进行
        lock = false; // 改变状态锁
        setTimeout(() => {
            fn()
            // 函数执行完,回调中改变状态锁
            lock = true;
        }, 1000);
    };
}


/**
 * 深拷贝 deepCopy  
 * param Object obj 要进行拷贝的对象
 * return Object obj 拷贝后的对象
 */

function deepCopy(obj) {
    let o = obj instanceof Array ? [] : {};
    for (let i in obj) {
        let val = obj[i];
        if (typeof val === "object") {
            o[i] = deepCopy(val);
        } else {
            o[i] = val;
        }
    }
    return o;
}



/**
 * 让网页变得干净   clearWebSite
 * tip:本质是将html-body内容隐藏并清除控制台
 */

function clearWebSite() {
    document.body.setAttribute('hidden', true);
    window.clear();//清除控制台
}

/**
 * 去除对象或数组的无效属性   delInvalidprops
 * param Object obj 待处理对象或数组
 * return <> obj 处理后的对象或数组
 */

function delInvalidprops(source) {
    if (typeof source !== 'object') return;
    const invalidProps = [undefined, null, '']

    if (Array.isArray(source)) {
        invalidProps.forEach(invalidProp => {
            source.forEach((item, idx) => {
                if (item === invalidProp) source.splice(idx, 1);
                if (typeof item === 'object') delInvalidprops(item);//递归删除--数组>对象
                
            })

        })


    } else {

        for (let key in source) {
            if (source[key] === invalidProps[0]) { delete source[key] };
            if (source[key] === invalidProps[1]) { delete source[key] };
            if (source[key] === invalidProps[2]) { delete source[key] };

        }
    }
    return source;

}



/**
 * 根据指定url下载文件   downloadByUrl
 * param1 string url 待下载文件url
 * param2 string name 指定下载文件的名称 --默认为'下载'
 * tip:html5新特性 --a 标签 download属性  部分浏览器不支持
 */


function downloadByUrl(url, name = '下载') {
    if (typeof url !== "string" || url.length === 0) return;
    const parseUrl = url.split('.');
    const extensionName = parseUrl.pop();
    let a = document.createElement("a");
    a.href = url;
    a.download = name + '.' + extensionName;
    document.body.appendChild(a);
    a.click();
    document.body.removeChild(a);

}

/**
 * enterEvent 回车事件监听
 * param  function  fn  业务函数
 */


function enterEvent(fn) {
    document.onkeydown = function (e) {
        e = e || window.event;
        if (e.keyCode === 13) {
            fn();
        }
    }
}



/**
 * pastTime 已过时间
 * param  Date  startTime  起始时间
 * return string 时间节点描述
 */

function pastTime(startTime) {

    let currentTime = Date.parse(new Date()),
        time = currentTime - startTime,
        day = parseInt(time / (1000 * 60 * 60 * 24)),
        hour = parseInt(time / (1000 * 60 * 60)),
        min = parseInt(time / (1000 * 60)),
        month = parseInt(day / 30),
        year = parseInt(month / 12);
    if (year) return year + "年前"
    if (month) return month + "个月前"
    if (day) return day + "天前"
    if (hour) return hour + "小时前"
    if (min) return min + "分钟前"
    return '刚刚'

}


/**
 * jsonFormat  自定义缩进的JSON格式化
 * param1  Object/Array  obj 待格式化的对象或数组
 * param2  number  space 缩进数
 * return string  jsonStr 格式化后的json字符串 
 */
function jsonFormat(obj, space) {
   
    return JSON.stringify(obj, null, space);
}



/* 其他常用函数--end*/






/*正则表达式 start*/

/**
 * 邮箱校验   isLegalEmail
 * param  string  email 待校验邮箱
 * return boolean 校验结果 
 */
function isLegalEmail(email) {
    return /^([a-zA-Z]|[0-9])(\w|\-)+@[a-zA-Z0-9]+\.([a-zA-Z]{2,4})$/.test(email);
}


/**
 * 中文名校验--(2-6)位    isLegalName
 * param  string  name 待校验中文名
 * return boolean 校验结果 
 */
function isLegalName(name) {
    return /^[\u4e00-\u9fa5]{2,6}$/.test(name);
}



/**
 * 身份证校验   isLegalIdCard
 * param  string  idCard 待校验身份证
 * return boolean 校验结果 
 */
function isLegalIdCard(idCard) {
    return /^[1-9]{1}[0-9]{14}$|^[1-9]{1}[0-9]{16}([0-9]|[xX])$/.test(idCard);
}

/**
 * 手机号码校验   isLegalPhone
 * param  string  phone 待校验手机号码
 * return boolean 校验结果 
 */
function isLegalPhone(phone) {
    return /^(((13[0-9]{1})|(15[0-9]{1})|(17[0-9]{1})|(18[0-9]{1}))+\d{8})$/.test(phone);
}


/*正则表达式 end*/