关于函数

异步函数判断

判断一个函数是否属于异步函数

const isAsyncFunction = (v) => Object.prototype…call(v) === ‘[object AsyncFunction]’

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

实用的JavaScript小技巧_html

关于对象

删除无效属性

当你需要删除一个对象中的属性值为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”}’)


关于web

重新加载当前页面

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

reload()


滚动到页面顶部

如果你需要将页面翻到最顶部

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

goToTop()


元素滚动

1.如果你希望将一个元素顺滑的滚动到可视区域的起点

const scrollToTop = (element) =>

element.scrollIntoView({ behavior: “smooth”, block: “start” })

scrollToTop(document.body)


2.如果你希望将一个元素顺滑的滚动到可视区域的终点

const scrollToBottom = (element) =>

element.scrollIntoView({ behavior: “smooth”, block: “end” })

scrollToBottom(document.body)


从给定文本中剥离html

当你需要在某个文本中将里面的标签全部过滤掉

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

stripHtml(‘


test

’) // ‘test’

重定向

当你需要跳转到其他页面

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


文本粘贴

当你需要复制文本到粘贴板上

const copy = (text) => navigator.clipboard?.writeText && navigator.clipboard.writeText(text)

copy(‘你需要粘贴的文本’)


关于日期

判断日期是否为今天

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


日期转换

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

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

formatYmd(new Date())


秒数转换

当你需要将秒数转换为 hh:mm:ss 格式

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

formatSeconds(200) // 00:03:20


获取某年某月的第一天

当你需要获取某年某月的第一天

const getLastDate = (d = new Date()) => new Date(d.getFullYear(), d.getMonth() + 1, 0);

getLastDate(new Date(‘2023-03-04’)) // Fri Mar 31 2023 00:00:00 GMT+0800 (中国标准时间)


获取某年月份天数

当你需要获取某年某个月份的总天数

const getDaysNum = (year, month) => new Date(year, month, 0).getDate()

const day = getDaysNum(2024, 2) // 29


比较两个对象

当你需要比较两个对象,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’


颜色格式转换

const hexToRgb = hex => hex.replace(/^#?([a-f\d])([a-f\d])([a-f\d])KaTeX parse error: Expected 'EOF', got '#' at position 22: …, r, g, b) => `#̲{r}r {r}r{g}g {g}g{b}${b}`).substring(1).match(/.{2}/g).map((x) => parseInt(x, 16));

hexToRgb(‘#00ffff’); // [0, 255, 255]

hexToRgb(‘#0ff’); // [0, 255, 255]


获取随机ip

当你需要生成一个ip地址

const randomIp = () =>

Array(4)

.fill(0)

.map((_, i) => Math.floor(Math.random() * 255) + (i === 0 ? 1 : 0))

.join(‘.’);


uuid

当你需要生成一个id

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

uuid()


获取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’)});