本文主要是介绍前端单行代码, 直接体现一个人的基础水平!!!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
文章目录
- 前端单行代码, 直接体现一个人的基础水平!!!
- 数组
- 生成数组
- 打乱数组
- 数组简单数据去重
- 数组唯一值数据去重
- 多数组取交集
- 查找最大值索引
- 查找最小值索引
- 找到最接近的数值
- 压缩多个数组
- 矩阵交换行和列
- 数字转换
- 进制转换
- web
- 滚动到页面顶部
- 元素滚动
- 文本粘贴
- 日期
- 秒数转换
- 数字
- 四舍五入
- 补零
- 对象
- 删除无效属性
- 反转对象键值
- 字符串转对象
- 其他
- 比较两个对象
- 随机颜色生成
- 颜色格式转换 16进制——>rgb
- 判断hex颜色值是否为深色
- 获取cookie
- 强制等待
前端单行代码, 直接体现一个人的基础水平!!!
数组
生成数组
当你需要要生成一个0-99的数组
const createArr = (n) => Array.from(new Array(n), (v, i) => i)
const arr = createArr(100) // 0 - 99 数组
const createArr = (n) => new Array(n).fill(0).map((v, i) => i)
createArr(100) // 0 - 99数组
打乱数组
当你有一个数组,你需要打乱这个数组的排序
const randomSort = list => list.sort(() => Math.random() - 0.5)
randomSort([0,1,2,3,4,5,6,7,8,9]) // 随机排列结果
数组简单数据去重
const removeDuplicates = list => [...new Set(list)]
removeDuplicates([0, 0, 2, 4, 5]) // [0,2,4,5]
数组唯一值数据去重
/*** 根据唯一值对数组进行去重* @param list 要去去重的数组* @param key 按照对象某一属性(key)去重*/const deWeightThree = (list: Array<any>, key: string) => [...list.reduce((prev, cur) => prev.set(cur[key], cur), new Map()).values(),];console.log(deWeightThree([{id: 1, name: 'jack'}, {id: 2, name: 'rose'}, {id: 1, name: 'jack'}], 'name'));
多数组取交集
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]
查找最大值索引
const indexOfMax = (arr) => arr.reduce((prev, curr, i, a) => (curr > a[prev] ? i : prev), 0);
indexOfMax([1, 3, 9, 7, 5]); // 2
const maxValueIndexof = (arr: number[]) => arr.indexOf(Math.max(...arr));maxValueIndexof([1, 3, 12, 5, 69, 7, 5]);//4
查找最小值索引
const indexOfMax = (arr) => arr.reduce((prev, curr, i, a) => (curr < a[prev] ? i : prev), 0);
indexOfMax([1, 3, 9, 7, 5]); // 5
const maxValueIndexof = (arr: number[]) => arr.indexOf(Math.min(...arr));maxValueIndexof([1, 3, 12, 5, 69, 7, 5]);//0
找到最接近的数值
当你需要在一个数组中找到一个最接近的值
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
压缩多个数组
当你需要将多个数组压缩成一个数组
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']]
矩阵交换行和列
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],] // ]);
数字转换
进制转换
将10进制转换成n进制,可以使用toString(n)
const toDecimal = (num, n = 10) => num.toString(n)
// 假设数字10要转换成2进制
toDecimal(10, 2) // '1010'
将n进制转换成10进制,可以使用parseInt(num, n)
// 10的2进制为1010
const toDecimalism = (num, n = 10) => parseInt(num, n)
toDecimalism(1010, 2)
web
滚动到页面顶部
const goToTop = () => window.scrollTo(0, 0);
goToTop()
元素滚动
如果你希望将一个元素顺滑的滚动到可视区域的起点
const scrollToTop = (element) =>element.scrollIntoView({ behavior: "smooth", block: "start" })
scrollToTop(document.body)
如果你希望将一个元素顺滑的滚动到可视区域的终点
const scrollToBottom = (element) =>element.scrollIntoView({ behavior: "smooth", block: "end" })scrollToBottom(document.body)// document.getElementById(id)?.scrollIntoView({// behavior: 'smooth',// // 定义动画过渡效果, "auto"或 "smooth" 之一。默认为 "auto"// block: 'center',// // 定义垂直方向的对齐, "start", "center", "end", 或 "nearest"之一。默认为 "start"// inline: 'nearest',// // 定义水平方向的对齐, "start", "center", "end", 或 "nearest"之一。默认为 "nearest"// });
文本粘贴
当你需要复制文本到粘贴板上
const copy = (text) => navigator.clipboard?.writeText && navigator.clipboard.writeText(text)
copy('你需要粘贴的文本')
日期
秒数转换
当你需要将秒数转换为 hh:mm:ss 格式
const formatSeconds = (s) => new Date(s * 1000).toISOString().substr(11, 8)
formatSeconds(200) // 00:03:20
数字
四舍五入
当你需要将小数点后的某些数字截断,并取四舍五入
const round = (n, decimals = 0) => Number(`${Math.round(`${n}e${decimals}`)}e-${decimals}`)
round(10.255, 2) // 10.26
补零
当你需要在一个数字num不足len位数的时候前面补零操作
const replenishZero = (num, len, zero = 0) => num.toString().padStart(len, zero)
replenishZero(8, 2) // 08
对象
删除无效属性
你需要删除一个对象中的属性值为null或undefined的所有属性
const removeNullUndefined = (obj) => Object.entries(obj).reduce((a, [k, v]) => (v == null ? a : ((a[k] = v), a)), {});removeNullUndefined({name: '', age: undefined, sex: null}) // { name: '' }
反转对象键值
当你需要将对象的键值对交换
const invert = (obj) => Object.keys(obj).reduce((res, k) => Object.assign(res, { [obj[k]]: k }), {})
invert({name: 'jack'}) // {jack: 'name'}
字符串转对象
当你需要将一串字符串比如'{name: "jack"}'转换成对象时,直接使用JSON.parse将会报错。
const strParse = (str) => JSON.parse(str.replace(/(\w+)\s*:/g, (_, p1) => `"${p1}":`).replace(/\'/g, "\""))strParse('{name: "jack"}')
其他
比较两个对象
当你需要比较两个对象,js的等于只能判断对象的地址是否相同,当地址不相同的时候无法判断两个对象的键值对是否一致
const isEqual = (...objects) => objects.every(obj => JSON.stringify(obj) === JSON.stringify(objects[0]))
isEqual({name: 'jack'}, {name: 'jack'}) // true
isEqual({name: 'jack'}, {name: 'jack1'}, {name: 'jack'}) // false
随机颜色生成
当你需要获取一个随机颜色
const getRandomColor = () => `#${Math.floor(Math.random() * 0xffffff).toString(16)}`
getRandomColor() // '#4c2fd7'
颜色格式转换 16进制——>rgb
当你需要将16进制的颜色转换成rgb
const hexToRgb = hex => hex.replace(/^#?([a-f\d])([a-f\d])([a-f\d])$/i, (_, r, g, b) => `#${r}${r}${g}${g}${b}${b}`).substring(1).match(/.{2}/g).map((x) => parseInt(x, 16));
hexToRgb('#00ffff'); // [0, 255, 255]
hexToRgb('#0ff'); // [0, 255, 255]
判断hex颜色值是否为深色
const hexIsDark = (hex: string) => {// 将Hex颜色转换为RGB颜色 这里也可以用上面的函数简介一些let result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex);let rgb = result? {r: parseInt(result[1], 16),g: parseInt(result[2], 16),b: parseInt(result[3], 16),}: null;let brightness: number = 0;if (rgb) brightness = 0.299 * rgb.r + 0.587 * rgb.g + 0.114 * rgb.b;return brightness < 128;
};
hexIsDark('#000000') //true
获取cookie
当你需要将cookie转换成对象
const getCookie = () => document.cookie.split(';').map((item) => item.split('=')).reduce((acc, [k, v]) => (acc[k.trim().replace('"', '')] = v) && acc, {})
getCookie()
强制等待
当你需要等待一段时间,但又不想写在setTimeout函数中,造成回调地狱
const sleep = async (t) => new Promise((resolve) => setTimeout(resolve, t));
sleep(2000).then(() => {console.log('time')});
这篇关于前端单行代码, 直接体现一个人的基础水平!!!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!