久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > 10個超實用的JavaScript技巧,讓你的日常工作更輕松

10個超實用的JavaScript技巧,讓你的日常工作更輕松

來源:千鋒教育
發(fā)布人:wjy
時間: 2022-09-09 13:46:46 1662702406

  在前面,我們也分享了很多關(guān)于JavaScript的技巧,今天我們再來看看這10個超級實用的技巧,希望能夠?qū)δ阌兴鶐椭?/p>

  1.過濾錯誤值

  如果要過濾數(shù)組中的false、0、null、undefined等值,可以這樣做:

  const array = [1, 0, undefined, 6, 7, ‘’, false]; array.filter(Boolean);

  2.判斷簡化

  如果有這樣的判斷:

  if(a === undefined || a === 10 || a=== 15 || a === null) { //… }

  可以使用數(shù)組來簡化這個判斷邏輯:

  if([undefined, 10, 15, null].includes(a)) { //… }

  這樣,代碼會更簡單,更容易擴(kuò)展。如果還有判斷需要等于a,可以直接加到數(shù)組中。

  3.初始化數(shù)組

  如果需要初始化一個指定長度的一維數(shù)組并指定一個默認(rèn)值,可以這樣完成:

  const array = Array(6).fill(‘’); // [‘’, ‘’, ‘’, ‘’, ‘’, ‘’]

  如果需要初始化一個指定長度的二維數(shù)組并指定一個默認(rèn)值,可以這樣做:

  const matrix = Array(6).fill(0).map(() => Array(5).fill(0));

  4.清空數(shù)組

  要清除數(shù)組,請將數(shù)組的長度設(shè)置為 0:

  let array = [“A”, “B”, “C”, “D”, “E”, “F”] array.length = 0 console.log(array) // []

  5.連接數(shù)組

  我們需要連接幾個數(shù)組,我們可以使用擴(kuò)展運(yùn)算符:

  const start = [1, 2] const end = [5, 6, 7] const numbers = [9, …start, …end, 8] // [9, 1, 2, 5, 6, 7 , 8]

  或者使用數(shù)組的 concat() 方法:

  const start = [1, 2, 3, 4] const end = [5, 6, 7] start. concat(end); // [1, 2, 3, 4, 5, 6, 7]

  但是在使用 concat() 方法時,如果要合并的數(shù)組很大,concat() 函數(shù)在創(chuàng)建單獨(dú)的新數(shù)組時會消耗大量內(nèi)存。這時候可以使用以下方法合并數(shù)組:

  Array.prototype.push.apply(start, end)

  這樣,顯著減少了內(nèi)存使用量。

  6.將數(shù)組元素轉(zhuǎn)換為數(shù)字

  如果你有一個數(shù)組,并且需要將數(shù)組中的元素轉(zhuǎn)換為數(shù)字,可以使用 map 方法來實現(xiàn):

  const array = [‘12’, ‘1’, ‘3.1415’, ‘-10.01’]; array.map(Number); // [12, 1, 3.1415, -10.01]

  這樣,map 將在遍歷數(shù)組時對數(shù)組的每個元素執(zhí)行 Number 構(gòu)造函數(shù)并返回結(jié)果。

  7.將類數(shù)組轉(zhuǎn)換為數(shù)組

  可以使用以下方法將類似數(shù)組的參數(shù)轉(zhuǎn)換為數(shù)組:

  Array.prototype.slice.call(arguments);

  除此之外,還可以使用展開運(yùn)算符來實現(xiàn):[…arguments]

  8.縮短console.log()

  每次調(diào)試都要寫很多console.log()會比較麻煩,可以用下面的形式來簡化這段代碼:

  const c = console.log.bind(document) c(321) c(“hello mygod”)

  每次執(zhí)行 c 方法時都會這樣做。

  9.刪除一個數(shù)組元素

  如果我們想刪除數(shù)組中的一個元素,可以使用delete來實現(xiàn),但是刪除后的元素會變成undefined,不會消失,執(zhí)行的時候會消耗很多時間,大部分情況下不能滿足我們要求。所以,你可以使用數(shù)組的 splice() 方法來移除數(shù)組元素:

  const array = [“a”, “b”, “c”, “d”] array.splice(0, 2) // [“a”, “b”]

  10.檢查對象是否為空

  我們需要檢查對象是否為空,我們可以使用如下:

  Object.keys({}).length // 0

  Object.keys({key: 1}).length // 1

  Object.keys() 方法用于獲取對象的鍵并返 回包含這些鍵值的數(shù)組。如果返回的數(shù)組長度為 0,則對象必須為空。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
軟件定制開發(fā)中的敏捷開發(fā)是什么?

軟件定制開發(fā)中的敏捷開發(fā)是什么軟件定制開發(fā)中的敏捷開發(fā),從宏觀上看,是一個高度關(guān)注人員交互,持續(xù)開發(fā)與交付,接受需求變更并適應(yīng)環(huán)境變化...詳情>>

2023-10-14 13:24:57
什么是PlatformIo?

PlatformIO是什么PlatformIO是一個全面的物聯(lián)網(wǎng)開發(fā)平臺,它為眾多硬件平臺和開發(fā)環(huán)境提供了統(tǒng)一的工作流程,有效簡化了開發(fā)過程,并能兼容各種...詳情>>

2023-10-14 12:55:06
云快照與自動備份有什么區(qū)別?

1、定義和目標(biāo)不同云快照的主要目標(biāo)是提供一種快速恢復(fù)數(shù)據(jù)的方法,它只記錄在快照時間點(diǎn)后的數(shù)據(jù)變化,而不是所有的數(shù)據(jù)。自動備份的主要目標(biāo)...詳情>>

2023-10-14 12:48:59
服務(wù)器為什么要用Linux?

服務(wù)器為什么要用Linux作為服務(wù)器操作系統(tǒng)的優(yōu)選,Linux在眾多選擇中脫穎而出。Linux作為服務(wù)器操作系統(tǒng)的優(yōu)選,有其獨(dú)特的優(yōu)勢和特點(diǎn)。包括其...詳情>>

2023-10-14 12:34:11
ORM解決的主要問題是什么?

ORM(對象關(guān)系映射)解決的主要問題是將關(guān)系數(shù)據(jù)庫與面向?qū)ο缶幊讨g的映射困境。在傳統(tǒng)的關(guān)系數(shù)據(jù)庫中,數(shù)據(jù)以表格的形式存儲,而在面向?qū)ο?..詳情>>

2023-10-14 12:26:19
快速通道