本文介绍: 当你需要手机号码格式化xxxxxxxxxxx的形式。当你需要一个数字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.补零

当你需要在一个数字num不足len位数时候前面补零操作

const replenishZero = (num, lenzero = 0) => num.().padStart(lenzero)
replenishZero(8, 2) // 08

4.数字正则

手机号格式化

当你需要将手机号码格式化成xxxxxxxxxxx的形式

const formatPhone = (strsign = '-') => 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), (vi) => i)
const arr = createArr(100) // 0 - 99 数组

方案2

const createArr = (n) => new Array(n).fill(0).map((vi) => 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进行投诉反馈,一经查实,立即删除

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注