欧美成人精品手机在线观看_69视频国产_动漫精品第一页_日韩中文字幕网 - 日本欧美一区二区

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

38個實用的JavaScript 技巧

admin
2024年10月13日 22:35 本文熱度 440

?

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

01、重新加載當前頁面

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

02、滾動到頁面頂部

如果需要將頁面移至最頂部的話,這個就非常有用。

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

03、元素滾動

如果希望將元素平滑地滾動到視口的起點

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

如果希望將元素平滑地滾動到視口的端點

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

04、檢查當前瀏覽器是否為Internet Explorer

const isIE = !!document.documentMode;

05、從給定文本中去除 HTML

當需要從一段文本中過濾掉所有標簽時,以下代碼就非常實用。

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

06、重定向

當需要導航到另一個頁面時。

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

07、文字粘貼

當需要將文本復制到剪貼板時

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

功能

08、異步函數檢查

確定函數是否異步。

const isAsyncFunction = (v) => Object.prototype.toString.call(v) === '[object AsyncFunction]'isAsyncFunction(async function () {}); // true

09、截斷數

當需要截斷小數點后的某些數字而不進行四舍五入時。

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的數組時。

//Method1const createArr = (n) => Array.from(new Array(n), (v, i) => i)const arr = createArr(100)
//Method2const 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'}) // trueisEqual({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技巧,請收藏好,以備不時之需,不用每次去翻找了。

最后,感謝你的閱讀,祝變成愉快!


該文章在 2024/10/14 11:07:43 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved