38个实用的JavaScript 技巧

开发 前端
今天这篇文章,我想跟大家分享一些我在日常工作中收集整理的一些有用的 JavaScript 技巧,希望这些技巧能够帮助你提升开发效率。

今天这篇文章,我想跟大家分享一些我在日常工作中收集整理的一些有用的 JavaScript 技巧,希望这些技巧能够帮助你提升开发效率。

1、重新加载当前页面

const reload = () => location.reload();
reload()

2、滚动到页面顶部

如果需要将页面移至最顶部的话,这个就非常有用。

const goToTop = () => window.scrollTo(0, 0);


goToTop()

3、元素滚动

如果希望将元素平滑地滚动到视口的起点

const scrollToTop = (element) =>
  element.scrollIntoView({ behavior: "smooth", block: "start" })


scrollToTop(document.body)

如果希望将元素平滑地滚动到视口的端点

const scrollToBottom = (element) =>
  element.scrollIntoView({ behavior: "smooth", block: "end" })
  scrollToBottom(document.body)

4、检查当前浏览器是否为Internet Explorer

const isIE = !!document.documentMode;

5、从给定文本中去除 HTML

当需要从一段文本中过滤掉所有标签时,以下代码就非常实用。

const stripHtml = (html) => new DOMParser().parseFromString(html, 'text/html').body.textContent || '';


stripHtml('<div>test</div>') // 'test'

6、重定向

当需要导航到另一个页面时。

const goTo = (url) => (location.href = url);

7、文字粘贴

当需要将文本复制到剪贴板时

const copy = (text) => navigator.clipboard?.writeText && navigator.clipboard.writeText(text)
copy('你需要粘贴的文本')

功能

8、异步函数检查

确定函数是否异步。

const isAsyncFunction = (v) => Object.prototype.toString.call(v) === '[object AsyncFunction]'


isAsyncFunction(async function () {}); // true

9、截断数

当需要截断小数点后的某些数字而不进行四舍五入时。

const toFixed = (n, fixed) => `${n}`.match(new RegExp(`^-?\d+(?:.\d{0,${fixed}})?`))[0]


toFixed(10.255, 2) // 10.25

10、四舍五入到最接近的

当需要截断小数点后的某些数字并四舍五入到最接近的数字时。

const round = (n, decimals = 0) => Number(`${Math.round(`${n}e${decimals}`)}e-${decimals}`)


round(10.255, 2) // 10.26

11、零填充

当需要在数字“num”开头用零填充直到达到“len”位时。

const replenishZero = (num, len, zero = 0) => num.toString().padStart(len, zero)


replenishZero(8, 2) // 08

12、删除无效属性

当需要删除对象中值为空或未定义的所有属性时。

const removeNullUndefined = (obj) => Object.entries(obj).reduce((a, [k, v]) => (v == null ? a : ((a[k] = v), a)), {});


removeNullUndefined({name: '', age: undefined, sex: null}) // { name: '' }

13、反转对象键值对

当需要交换对象的键值对时。

const invert = (obj) => Object.keys(obj).reduce((res, k) => Object.assign(res, { [obj[k]]: k }), {})


invert({name: 'jack'}) // {jack: 'name'}

14、字符串到对象

当需要将‘{name: “jack”}’这样的字符串转换为对象时,直接使用 JSON.parse 会导致错误。

const strParse = (str) => JSON.parse(str.replace(/(\w+)\s*:/g, (_, p1) => `"${p1}":`).replace(/\'/g, "\""))


strParse('{name: "jack"}')

日期

15、检查日期是否是今天

const isToday = (date) => date.toISOString().slice(0, 10) === new Date().toISOString().slice(0, 10)

16、日期转换

当需要将日期转换为 YYYY-MM-DD 格式时。

const formatYmd = (date) => date.toISOString().slice(0, 10);
formatYmd(new Date())

17、第二次转换

当需要将秒转换为 hh:mm:ss 格式时。

const formatSeconds = (s) => new Date(s * 1000).toISOString().substr(11, 8)


formatSeconds(200) // 00:03:20

18、获取某年某月的第一天

const getFirstDate = (d = new Date()) => new Date(d.getFullYear(), d.getMonth(), 1);


getFirstDate(new Date('2024/05'))

19、获取某年某月的最后一天

const getLastDate = (d = new Date()) => new Date(d.getFullYear(), d.getMonth() + 1, 0);
getLastDate(new Date('2023/03/04'))

20、获取给定年份的特定月份的总天数

const getDaysNum = (year, month) => new Date(year, month, 0).getDate()  
const day = getDaysNum(2024, 2) // 29

Array

21、生成数组

当需要生成0到99的数组时。

//Method1
const createArr = (n) => Array.from(new Array(n), (v, i) => i)
const arr = createArr(100)
//Method2
const createArr = (n) => new Array(n).fill(0).map((v, i) => i)
createArr(100)

22、随机排列数组

当有一个数组并且需要打乱其顺序时。

const randomSort = list => list.sort(() => Math.random() - 0.5)
randomSort([0,1,2,3,4,5,6,7,8,9]) // Random permutation result

23、简单的数组去重

当需要仅保留数组中每个重复元素的一个实例时。

const removeDuplicates = list => [...new Set(list)]
removeDuplicates([0, 0, 2, 4, 5]) // [0,2,4,5]

24、数组唯一值去重

根据唯一值对数组进行重复数据删除。

const duplicateById = list => [...list.reduce((prev, cur) => prev.set(cur.id, cur), new Map()).values()]
duplicateById([{id: 1, name: 'jack'}, {id: 2, name: 'rose'}, {id: 1, name: 'jack'}])
// [{id: 1, name: 'jack'}, {id: 2, name: 'rose'}]

25、多个数组的交集

当需要找到多个数组的交集时。

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]

26、查找最大值索引

当需要查找数组中最大值的索引时。

const indexOfMax = (arr) => arr.reduce((prev, curr, i, a) => (curr > a[prev] ? i : prev), 0);
indexOfMax([1, 3, 9, 7, 5]); // 2

27、查找最小值索引

当需要查找数组中最小值的索引时。

const indexOfMin = (arr) => arr.reduce((prev, curr, i, a) => (curr < a[prev] ? i : prev), 0)
indexOfMin([2, 5, 3, 4, 1, 0, 9]) // 5

28、查找最接近的数值

当需要在数组中查找最接近给定数字的值时。

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

29、压缩多个数组

当需要将多个数组压缩为一个数组时。

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']]

30、矩阵行列交换

当需要交换矩阵的行和列时。

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],
     ]             //  ]
 );

数字转换

31、基数转换

要将基数 10 转换为基数 n,可以使用 toString(n)

const toDecimal = (num, n = 10) => num.toString(n) 
// If the number 10 needs to be converted into binary (base 2)
toDecimal(10, 2) // '1010'

要将基数 n 转换为基数 10,可以使用 parseInt(num, n)

const toDecimalism = (num, n = 10) => parseInt(num, n)
toDecimalism(1010, 2)
其他的

32、比较两个对象

当需要比较两个对象时,JavaScript的相等运算符只能判断对象地址是否相同。当地址不同时,无法判断两个对象的键值对是否相同。

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

33、随机颜色生成

当需要获得随机颜色时。

const getRandomColor = () => `#${Math.floor(Math.random() * 0xffffff).toString(16)}`
getRandomColor() // '#4c2fd7'

34、颜色格式转换

当需要将十六进制颜色转换为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]

35、获取随机IP

当需要生成IP地址时。

const randomIp = () =>
    Array(4)
        .fill(0)
        .map((_, i) => Math.floor(Math.random() * 255) + (i === 0 ? 1 : 0))
        .join('.');

36、uuid

当需要生成ID时。

const uuid = (a) => (a ? (a ^ ((Math.random() * 16) >> (a / 4))).toString(16) : ([1e7] + -1e3 + -4e3 + -8e3 + -1e11).replace(/[018]/g, uuid))
uuid()

37、获取cookie

当需要将cookie转换为对象时。

const getCookie = () => document.cookie
    .split(';')
    .map((item) => item.split('='))
    .reduce((acc, [k, v]) => (acc[k.trim().replace('"', '')] = v) && acc, {})
getCookie()

38、强制等待

当需要等待一段时间,但又不想写在setTimeout函数中,造成回调地狱时。

const sleep = async (t) => new Promise((resolve) => setTimeout(resolve, t));
sleep(2000).then(() => {console.log('time')});

总结

以上就是我今天跟你分享的38个实用的JavaScript技巧,请收藏好,以备不时之需,不用每次去翻找了。

责任编辑:华轩 来源: web前端开发
相关推荐

2023-08-11 17:39:43

JavaScriptWeb 应用程序

2023-11-26 17:54:07

JavaScript开发

2021-03-15 08:13:19

JavaScript开发代码

2016-05-10 10:16:13

JavaScript技巧

2023-05-04 23:54:02

JavaScrip代码技巧

2017-10-30 17:25:11

javascript

2023-07-24 07:11:43

2013-12-31 09:26:31

JavaScript技巧

2022-08-16 10:53:56

JavaScript前端技巧

2019-06-14 14:15:07

Javascript调试技巧代码

2023-02-13 15:09:01

开发webCSS技巧

2020-07-02 08:27:47

Javascript

2024-02-26 08:20:00

CSS开发

2020-08-14 10:57:49

开发技能代码

2023-12-19 13:31:00

CSS前端技巧

2022-09-02 23:08:04

JavaScript技巧开发

2020-09-29 08:14:46

JavaScript开发代码

2020-06-23 08:28:26

前端开发技巧

2022-12-22 14:44:06

JavaScript技巧

2022-12-25 16:03:31

JavaScript技巧
点赞
收藏

51CTO技术栈公众号