19个提高工作效率的JavaScript单行代码
大约 2 分钟约 693 字...
1.# 生成随机字符串
当我们需要一个唯一 id 时,通过Math.random
创建一个随机字符串简直不要太方便噢!!!
const randomString = () => Math.random().toString(36).slice(2);
randomString(); // gi1qtdego0b
randomString(); // f3qixv40mot
randomString(); // eeelv1pm3ja
2.# 转义 HTML 特殊字符
解决 XSS 方法之一就是转义 HTML。
const escape = (str) =>
str.replace(
/[&<>"']/g,
(m) =>
({ "&": "&", "<": "<", ">": ">", '"': """, "'": "'" }[
m
])
);
escape('<div class="medium">Hi Medium.</div>');
// <div class="medium">Hi Medium.</div>
3.# 单词首字母大写
const uppercaseWords = (str) =>
str.replace(/^(.)|\s+(.)/g, (c) => c.toUpperCase());
uppercaseWords("hello world"); // 'Hello World'
4.# 将字符串转换为小驼峰
const toCamelCase = (str) =>
str.trim().replace(/[-_\s]+(.)?/g, (_, c) => (c ? c.toUpperCase() : ""));
toCamelCase("background-color"); // backgroundColor
toCamelCase("-webkit-scrollbar-thumb"); // WebkitScrollbarThumb
toCamelCase("_hello_world"); // HelloWorld
toCamelCase("hello_world"); // helloWorld
5.# 删除数组中的重复值
得益于 ES6,使用 Set 数据类型来对数组去重太方便了。
const removeDuplicates = (arr) => [...new Set(arr)];
console.log(removeDuplicates([1, 2, 2, 3, 3, 4, 4, 5, 5, 6]));
// [1, 2, 3, 4, 5, 6]
6.# 铺平一个数组
const flat = (arr) =>
[].concat.apply(
[],
arr.map((a) => (Array.isArray(a) ? flat(a) : a))
);
// Or
const flat = (arr) =>
arr.reduce((a, b) => (Array.isArray(b) ? [...a, ...flat(b)] : [...a, b]), []);
flat(["cat", ["lion", "tiger"]]); // ['cat', 'lion', 'tiger']
7.# 移除数组中的假值
const removeFalsy = (arr) => arr.filter(Boolean);
removeFalsy([
0,
"a string",
"",
NaN,
true,
5,
undefined,
"another string",
false,
]);
// ['a string', true, 5, 'another string']
8.# 确认一个数字是奇数还是偶数
const isEven = (num) => num % 2 === 0;
isEven(2); // true
isEven(1); // false
9.# 获取两个数字之间的随机数
const random = (min, max) => Math.floor(Math.random() * (max - min + 1) + min);
random(1, 50); // 25
random(1, 50); // 34
10.# 计算平均值
const average = (...args) => args.reduce((a, b) => a + b) / args.length;
average(1, 2, 3, 4, 5); // 3
11.# 将数字截断到固定的小数点
const round = (n, d) => Number(Math.round(n + "e" + d) + "e-" + d);
round(1.005, 2); //1.01
round(1.555, 2); //1.56
12.# 计算两个日期之间天数
const diffDays = (date, otherDate) =>
Math.ceil(Math.abs(date - otherDate) / (1000 * 60 * 60 * 24));
diffDays(new Date("2021-11-3"), new Date("2022-2-1")); // 90
13.# 从日期中获取是一年中的哪一天
const dayOfYear = (date) =>
Math.floor(
(date - new Date(date.getFullYear(), 0, 0)) / (1000 * 60 * 60 * 24)
);
dayOfYear(new Date()); // 74
14.# 获取一个随机的颜色值
const randomColor = () =>
`#${Math.random().toString(16).slice(2, 8).padEnd(6, "0")}`;
randomColor(); // #9dae4f
randomColor(); // #6ef10e
15.# 将 RGB 颜色转换为十六进制颜色值
const rgbToHex = (r, g, b) =>
"#" + ((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1);
rgbToHex(255, 255, 255); // '#ffffff'
16.# 清除所有的 cookie
const clearCookies = () =>
document.cookie
.split(";")
.forEach(
(c) =>
(document.cookie = c
.replace(/^ +/, "")
.replace(/=.*/, `=;expires=${new Date().toUTCString()};path=/`))
);
17.# 检测黑暗模式
const isDarkMode =
window.matchMedia &&
window.matchMedia("(prefers-color-scheme: dark)").matches;
18.# 交换两个变量的值
[foo, bar] = [bar, foo];
19.# 暂停一会
const pause = (millis) => new Promise((resolve) => setTimeout(resolve, millis));
const fn = async () => {
await pause(1000);
console.log("fatfish"); // 1s later
};
fn();
Powered by Waline v2.15.5