js--常用函数



  • 微信扫码关注公众号 :前端前端大前端,追求更精致的阅读体验 ,一起来学习啊
  • 关注后发送关键资料,免费获取一整套前端系统学习资料和老男孩python系列课程
    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*/