本文介绍: 当你需要将手机号码格式化成xxx–xxxx–xxxx的形式。当你需要在一个数字num不足len位数的时候前面补零操作。当你需要将一段文本中的多个空格合并成一个空格。当你需要将数组中的所有重复的元素只保留一个。当你有一个数组,你需要打乱这个数组的排序。当你需要在一个数组中找到一个最接近的值。当你需要将一个矩阵的行和列进行互相交换。但你需要找到一个数组中的最大值的索引。当你需要找到一个数组中的最小值的索引。当你需要要生成一个0-99的数组。当你需要将多个数组压缩成一个数组。当你需要取多个数组中的交集。
关于数字
1.进制转换
将十进制数字转换成其他N进制的数字,可以使用toString(n)
const toDecimal = (num, n = 10) => num.(n)
// 假设数字10要转换成2进制
toDecimal(10, 2) // '1010'
将n进制数组转换成十进制,可以使用parseInt(num, n)
// 10的2进制为1010
const toDecimalism = (num, n = 10) => parseInt(num, n)
toDecimalism(1010, 2)
2.四舍五入
const toFixed = (n, fixed) => `${n}`.match(new RegExp(`^-?d+(?:.d{0,${fixed}})?`))[0]
toFixed(10.255, 2) // 10.25
3.补零
const replenishZero = (num, len, zero = 0) => num.().padStart(len, zero)
replenishZero(8, 2) // 08
4.数字正则
手机号格式化
const formatPhone = (str, sign = '-') => str.replace(/(W|s)/g, "").split(/^(d{3})(d{4})(d{4})$/).filter(item => item).join(sign)
formatPhone('13123456789') // '131-2345-6789'
formatPhone('13 1234 56 789', ' ') // '131 2345 6789'
去除多余空格
const setTrimOut = str => str.replace(/ss+/g, ' ')
const str = setTrimOut('hello, jack') //
关于数组
1.生成数组
当你需要要生成一个0-99的数组
方案1
const createArr = (n) => Array.from(new Array(n), (v, i) => i)
const arr = createArr(100) // 0 - 99 数组
方案2
const createArr = (n) => new Array(n).fill(0).map((v, i) => i)
createArr(100) // 0 - 99数组
2.打乱数组
当你有一个数组,你需要打乱这个数组的排序
const randomSort = list => list.sort(() => Math.random() - 0.5)
randomSort([0,1,2,3,4,5,6,7,8,9]) // 随机排列结果
3.数组去重
const removeDuplicates = list => [...new Set(list)]
removeDuplicates([0, 0, 2, 4, 5]) // [0,2,4,5]
4.多数组取交集
当你需要取多个数组中的交集
const intersection = (a, ...arr) => [...new Set(a)].filter((v) => arr.every((b) => b.includes(v)))
intersection([1, 2, 3, 4], [2, 3, 4, 7, 8], [1, 3, 4, 9])
// [3, 4]
5.查找最大值索引
const indexOfMax = (arr) => arr.reduce((prev, curr, i, a) => (curr > a[prev] ? i : prev), 0);
indexOfMax([1, 3, 9, 7, 5]); // 2
6.查找最小值索引
当你需要找到一个数组中的最小值的索引
const indexOfMin = (arr) => arr.reduce((prev, curr, i, a) => (curr < a[prev] ? i : prev), 0)
indexOfMin([2, 5, 3, 4, 1, 0, 9]) // 5
7.找到最接近的数值
当你需要在一个数组中找到一个最接近的值
const closest = (arr, n) => arr.reduce((prev, curr) => (Math.abs(curr - n) < Math.abs(prev - n) ? curr : prev))
closest([29, 87, 8, 78, 97, 20, 75, 33, 24, 17], 50) // 33
8.压缩多个数组
const zip = (...arr) => Array.from({ length: Math.max(...arr.map((a) => a.length)) }, (_, i) => arr.map((a) => a[i]))
zip([1,2,3,4], ['a', 'b', 'c', 'd'], ['A', 'B', 'C', 'D'])
// [[1, 'a', 'A'], [2, 'b', 'B'], [3, 'c', 'C'], [4, 'd', 'D']]
9.矩阵交换行和列
const transpose = (matrix) => matrix[0].map((col, i) => matrix.map((row) => row[i]));
transpose(
[ // [
[1, 2, 3], // [1, 4, 7],
[4, 5, 6], // [2, 5, 8],
[7, 8, 9], // [3, 6, 9],
] // ]
);
原文地址:https://blog.csdn.net/GUDUzhongliang/article/details/132206136
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_24390.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。