精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

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}$$`).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開發代碼

2017-10-30 17:25:11

javascript

2023-05-04 23:54:02

JavaScrip代碼技巧

2016-05-10 10:16:13

JavaScript技巧

2013-12-31 09:26:31

JavaScript技巧

2025-03-03 00:15:00

JavaScript開發效率

2023-07-24 07:11:43

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前端技巧

2020-06-23 08:28:26

前端開發技巧

2023-10-26 18:03:14

索引Python技巧

2020-05-27 11:25:48

開發技能代碼

2015-12-21 10:53:38

網絡邊界安全信息安全策略
點贊
收藏

51CTO技術棧公眾號

999在线精品| 免费在线看污片| 久久天堂精品| 精品国产一区av| 四虎精品一区二区| 天天综合网站| 亚洲最色的网站| 欧洲成人一区二区| a天堂视频在线| 国产精品婷婷| 久久手机免费视频| 国产女主播喷水高潮网红在线| 国产精品伊人| 天天色天天操综合| 一级一片免费播放| 三级做a全过程在线观看| 久久草av在线| 日本亚洲欧美成人| 久久中文字幕在线观看| 成人在线亚洲| 亚洲欧美国产另类| 久久久精品人妻一区二区三区| 桃子视频成人app| 亚洲一二三四在线观看| 国产福利片一区二区| 久青青在线观看视频国产| 国产成人aaa| 91精品视频一区| 超碰在线观看91| 国产欧美高清| 欧美日本精品在线| 三上悠亚作品在线观看| 欧美精选视频在线观看| 日韩精品丝袜在线| 亚洲图片欧美另类| 色综合一区二区日本韩国亚洲 | 日韩精品在线观看免费| 欧美激情aⅴ一区二区三区| 中文字幕视频在线免费欧美日韩综合在线看 | 国产亚洲小视频| 希岛爱理一区二区三区| 尤物九九久久国产精品的分类 | 日产精品99久久久久久| 国产午夜精品无码| 亚洲网站啪啪| 欧美激情aaaa| 久久久精品99| 欧美日韩一视频区二区| 色综合久久精品亚洲国产| www欧美com| 亚洲区综合中文字幕日日| 色噜噜亚洲精品中文字幕| 国产午夜福利一区| 欧美日韩激情在线一区二区三区| 亚洲跨种族黑人xxx| 特级西西人体wwwww| 欧美日韩一区二区三区四区不卡 | 翔田千里一区二区| 91成人精品网站| 国产99久久久| 久久一区二区三区超碰国产精品| 4p变态网欧美系列| 少妇高潮av久久久久久| 玖玖视频精品| 国产精品久久二区| 97超碰国产在线| 国产一区二区精品久久| 91美女高潮出水| 超碰免费在线97| www.欧美日韩| 欧洲精品亚洲精品| av电影在线网| 1024精品合集| 欧美午夜小视频| 女人让男人操自己视频在线观看 | 91精品国产91久久久久| 青青青国产在线| 青青草91视频| 91在线看www| 可以免费看毛片的网站| 久久伊人蜜桃av一区二区| 亚洲二区自拍| 日本在线视频www鲁啊鲁| 图片区小说区区亚洲影院| www.亚洲天堂网| 久久精品超碰| 亚洲成人精品久久久| 加勒比一区二区| 91久久夜色精品国产按摩| 欧美激情久久久久| 色老头一区二区| 国产酒店精品激情| 麻豆一区区三区四区产品精品蜜桃| 国产在线黄色| 夜夜操天天操亚洲| 成年网站在线播放| 九色丨蝌蚪丨成人| 日韩资源在线观看| 免费观看成人毛片| 国产揄拍国内精品对白| 久久久精彩视频| 国内外激情在线| 色综合天天综合网国产成人综合天| 色免费在线视频| 色天下一区二区三区| www.精品av.com| 色av性av丰满av| 久久超碰97人人做人人爱| 久久婷婷开心| 人人超在线公开视频| 在线观看国产91| 国产女人18毛片水真多18| 成人三级视频| 欧美在线日韩在线| av av片在线看| 中文av一区二区| 久久久免费视频网站| a看欧美黄色女同性恋| 视频在线观看一区二区| 成人免费毛片男人用品| 成人午夜视频免费看| 国产精品夜夜夜爽张柏芝| 欧美91看片特黄aaaa| 亚洲电影免费观看高清完整版在线 | 欧美激情啊啊啊| 国产喷水福利在线视频| 国产女人水真多18毛片18精品视频| 国产美女主播在线| 欧美一级片网址| 久久久精品美女| 国产偷人爽久久久久久老妇app| 91在线视频在线| 又大又硬又爽免费视频| 中文字幕区一区二区三| 美女视频黄免费的亚洲男人天堂| 中文字幕乱码无码人妻系列蜜桃| 国产午夜精品一区二区三区嫩草| 欧美久久久久久久久久久久久| 日韩中文字幕在线一区| 欧美xxxx18国产| www.久久综合| 亚洲小说欧美激情另类| 色婷婷狠狠18禁久久| 欧美aⅴ99久久黑人专区| 91天堂在线观看| 黄色免费在线网站| 欧美一区二区三区播放老司机| 少妇视频一区二区| 精品一二三四在线| 小说区视频区图片区| 国产午夜久久av| 九九久久久久99精品| 国产福利第一页| 亚洲在线成人精品| 在线观看亚洲免费视频| 中日韩视频在线观看| 美脚丝袜一区二区三区在线观看| 成人香蕉视频| 一本色道久久88亚洲综合88| 中文字幕精品一区二区精| 亚洲欧美综合在线精品| 9191在线视频| 在线精品一区二区| 麻豆91蜜桃| 狠狠久久伊人中文字幕| 久久亚洲国产精品| 内射无码专区久久亚洲| 欧美日韩亚洲91| 性欧美精品男男| 国产在线看一区| 国产a级片网站| 国产精品国产一区二区| 少妇视频在线观看| 中文字幕日韩免费视频| 国产视频第一页| 黄色一区二区在线| 国产熟女一区二区| 国产精品一区二区视频| 无码人妻精品一区二区三区在线| 日韩国产欧美| 99re视频在线| 日韩精品三区| 欧美乱大交xxxxx| 黄色在线视频观看网站| 91精品麻豆日日躁夜夜躁| 福利一区二区三区四区| 欧美激情在线看| 亚洲一级Av无码毛片久久精品| 久久婷婷影院| 少妇大叫太大太粗太爽了a片小说| 人人精品亚洲| 91免费人成网站在线观看18| caoporn视频在线| 色偷偷噜噜噜亚洲男人的天堂| 超碰福利在线观看| 欧美日韩精品高清| 99久在线精品99re8热| 亚洲色图一区二区| 蜜桃传媒一区二区亚洲av| 国产酒店精品激情| 免费看污黄网站| 最新国产乱人伦偷精品免费网站| 亚洲人成网站在线观看播放| 国产精品45p| 亚洲一区二区在线播放| 免费电影日韩网站| 久久久久亚洲精品成人网小说| 99re在线视频| 国产丝袜一区二区三区免费视频| 国产又粗又黄又爽视频| 日韩欧美a级成人黄色| 欧美成人一区二区三区高清| 日本一区二区免费在线| 久久无码专区国产精品s| 美女视频一区二区| 日韩精品一区二区三区色欲av| 亚洲午夜激情在线| 400部精品国偷自产在线观看| 国产一区日韩| 久久精品99久久| 中文字幕一区图| 91中文字幕在线观看| 成人福利一区二区| 国产成人精品综合久久久| 白浆在线视频| 久久久久九九九九| 亚洲91av| 欧美精品手机在线| 黄色免费在线看| www国产精品视频| 77777影视视频在线观看| 亚洲欧美国产精品| 欧洲毛片在线| 亚洲奶大毛多的老太婆| 亚洲欧美日韩动漫| 日韩电影中文 亚洲精品乱码| 国产自产一区二区| 精品精品欲导航| 懂色av蜜臀av粉嫩av分享吧| 精品蜜桃在线看| 色欲av伊人久久大香线蕉影院| 欧美www视频| 丰满人妻一区二区三区无码av | 精品国产乱码久久久久久1区二区| 麻豆91精品91久久久的内涵| 午夜精品在线免费观看| 日本午夜精品一区二区三区电影| 男人舔女人下面高潮视频| 水蜜桃久久夜色精品一区的特点| 99蜜桃臀久久久欧美精品网站| 国产女优一区| 成人在线观看a| 男男视频亚洲欧美| 高清av免费看| 国产成人福利片| 毛茸茸free性熟hd| 久久久久国产精品麻豆| 在线观看亚洲大片短视频| 国产精品毛片久久久久久久| 永久免费看片直接| 夜夜精品视频一区二区| 日韩精品在线不卡| 一本到不卡精品视频在线观看| 中国a一片一级一片| 欧美日韩高清在线播放| 精品人妻伦一区二区三区久久| 精品国产a毛片| 日韩电影在线观看完整版| 一个色综合导航| 黄色片网站在线| 97香蕉超级碰碰久久免费的优势| 免费成人直播| 92国产精品久久久久首页 | 在线观看视频亚洲| 国产精品剧情| 91精品国产高清久久久久久久久 | 欧美成人bangbros| 欧洲亚洲在线| 久久在线视频在线| 三级在线观看视频| 国产欧美在线视频| 卡一精品卡二卡三网站乱码| 日韩精品欧美在线| 欧美激情偷拍| 国产黄色特级片| 国产东北露脸精品视频| 在哪里可以看毛片| 亚洲精品国产第一综合99久久| 欧美日韩一二三四区| 51精品秘密在线观看| 三级国产在线观看| 欧美成年人视频| 玛雅亚洲电影| 超碰在线97av| 日本久久一二三四| 国产毛片视频网站| 国产精品一二三| 日韩女同一区二区三区| 亚洲成人动漫在线观看| 一区二区美女视频| 亚洲欧美一区二区三区在线| 中文字幕中文字幕在线中高清免费版| 日本高清视频一区| 午夜电影一区| 在线观看一区二区三区三州| 亚洲国产1区| www.成年人| 国产丝袜欧美中文另类| 日本少妇全体裸体洗澡| 欧美一区二区三区电影| √新版天堂资源在线资源| 97婷婷涩涩精品一区| 久久伊人精品| 亚洲亚洲精品三区日韩精品在线视频| 99热这里只有成人精品国产| 香蕉视频xxxx| 国产欧美日韩久久| www.国产一区二区| 亚洲国内精品视频| 日本欧美电影在线观看| 成人av色在线观看| 欧美日韩中文字幕一区二区三区| 国产97在线 | 亚洲| 丁香啪啪综合成人亚洲小说 | 91久久精品日日躁夜夜躁国产| 国产精品一区高清| 人妻熟女一二三区夜夜爱| 99九九99九九九视频精品| 久久综合色综合| 欧美刺激午夜性久久久久久久| 精精国产xxxx视频在线| 国产欧美中文字幕| 日韩高清欧美| 欧美特黄aaa| 国产精品久久久久久久久图文区| 中文精品久久久久人妻不卡| 亚洲欧美日韩网| 中文字幕一区久| 清纯唯美一区二区三区| 久久亚洲图片| 在线免费看视频| 欧美日韩精品专区| 毛片在线不卡| 99免费在线观看视频| 欧美特黄一级| av免费观看不卡| 欧美日韩免费在线观看| 青青草手机在线| 国产精品久久久久高潮| 日韩理论电影| www.桃色.com| 一区二区三区日韩欧美| 六月丁香综合网| 国产91精品高潮白浆喷水| 国产一区国产二区国产三区| wwww.国产| 亚洲人精品一区| 后进极品白嫩翘臀在线视频| 韩国一区二区电影| 美女少妇全过程你懂的久久 | 免费在线观看黄网站| 日韩av最新在线观看| 免费成人美女女| 异国色恋浪漫潭| 成人app下载| 天堂网免费视频| 久久久精品电影| 国产精品xxx在线观看| 久久久免费视频网站| 亚洲欧洲日韩av| 亚洲精品国产一区二| 欧美性受xxxx白人性爽| 日本激情一区| 亚洲精品久久一区二区三区777| 午夜激情一区二区三区| 国产在线超碰| 91亚洲精品在线| 国产精品久久久久9999高清| 九九九视频在线观看| 欧美一区二区三区啪啪| 黄色在线网站噜噜噜| 亚洲精品白虎| 成人一区二区三区在线观看| 国产真人无遮挡作爱免费视频| 久久久国产一区二区| 日韩高清成人在线| www.国产福利| 色综合视频在线观看| 免费黄网在线观看| 裸模一区二区三区免费| 国产在线观看免费一区| 销魂美女一区二区| 欧美激情第99页| 欧美日韩激情| 黄色av网址在线观看| 91麻豆精品国产综合久久久久久| 美女高潮在线观看| 亚洲免费视频播放| 国产欧美一区二区三区在线看蜜臀 | 午夜久久久久久久久久久|