JavaScript数字数组的13个实用小技巧
关于数字
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, len, zero = 0) => num.().padStart(len, zero) replenishZero(8, 2) // 08
4.数字正则
手机号格式化
当你需要将手机号码格式化成xxx-xxxx-xxxx的形式
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(/\s\s+/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], ] // ] );
总结
到此这篇关于JavaScript数字数组的13个实用小技巧的文章就介绍到这了,更多相关JS数字数组技巧内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
使用requestAnimationFrame实现js动画性能好
requestAnimationFrame优于setTimeout/setInterval的地方在于它是由浏览器专门为动画提供的API,在运行时浏览器会自动优化方法的调用,并且如果页面不是激活状态下的话,动画会自动暂停,有效节省了CPU开销,这篇文章给大家详细介绍使用requestAnimationFrame实现js动画2015-08-08javascript 支持链式调用的异步调用框架Async.Operation
javascript 支持链式调用的异步调用框架Async.Operation2009-08-08javascript截取字符串(通过substring实现并支持中英文混合)
用js方法substring()、方法substr()实现如标题所示的截取字符串并支持中英文混合,具体代码如下,感兴趣的各位可以参考下哈2013-06-06
最新评论