成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JavaScript重構技巧 — 數組,類名和條件

開發 前端
JavaScript 是一種易于學習的編程語言,編寫運行并執行某些操作的程序很容易。然而,要編寫一段干凈的JavaScript 代碼是很困難的。

JavaScript 是一種易于學習的編程語言,編寫運行并執行某些操作的程序很容易。然而,要編寫一段干凈的JavaScript 代碼是很困難的。

[[329242]]

在本文中,我們學習如何使用數組來代替條件語句,以及如何使用classList操作類名。

用數組檢查替換長表達式

平時開發中,我們可能會寫如下的代碼:

  1. if (fruit === 'apple' || fruit === 'orange' || fruit === 'grape') { 
  2.   //... 

對于上面,我們可以使用一些數組方法來減少條件表達式的長度。

一種方法是使用數組的include方法:

  1. if (['apple''orange' ,'grape'].includes(fruit)) { 
  2.   //... 

如果傳遞給參數的值包含在數組實例中,include方法返回true,否則返回false。

另一種方法是使用數組的some方法:

  1. if (['apple''orange''grape'].some(a => a === fruit)) { 
  2.   //... 

通過some方法,我們可以檢查回調中是否存在具有給定條件的數組元素。

如果存在一個或多個,則返回true,否則返回false。

在 DOM 元素中使用 classList 屬性

檢查 DOM 元素中是否存在類并操作多個類的最簡單方法是使用classList屬性。

例如,如果要添加多個類,可以使用下面方式:

  1. const p = document.querySelector('p'); 
  2. p.classList.add('foo'); 
  3. p.classList.add('bar'); 
  4. p.classList.add('baz'); 

這樣,我們可以添加多個類而無需操作字符串。我們只是獲得DOM元素對象的classList屬性,然后調用add通過將帶有類名的字符串傳遞到add方法中來添加類。

現在,渲染的DOM元素具有foo,bar和baz類。

同樣,我們可以調用classList屬性的remove方法,該方法使用一個帶有要刪除的類名的字符串來刪除該類。

例如,我們可以這樣寫:

  1. const p = document.querySelector('p'); 
  2. p.classList.add('foo'); 
  3. p.classList.add('bar'); 
  4. p.classList.add('baz'); 
  5. p.classList.remove('baz'); 

要檢查 DOM 元素對象中是否存在類名,可以使用contains方法。

例如,我們可以這樣寫:

  1. const p = document.querySelector('p'); 
  2. p.classList.add('foo'); 
  3. p.classList.add('bar'); 
  4. const hasBaz = p.classList.contains('baz'); 

上面判斷 p 元素是否包含 baz 類,因為 p 沒有包含 baz類,所以返回false。

classList屬性還有toggle方法,表示切換類(添加或者移除),例如下面的代碼:

  1. const p = document.querySelector('p'); 
  2. const button = document.querySelector('button'); 
  3. p.classList.add('foo'); 
  4. p.classList.add('bar'); 
  5.  
  6. button.onclick = () => { 
  7.   p.classList.toggle('bar'); 

每點擊一次按鈕,p 的上 bar 類就會添加或者移除。

clasList屬性有一個類似數組的可迭代對象,稱為DOMTokenList對象。因此,我們可以使用展開操作符將其轉換為數組,將clasList轉換為一個帶有類名的字符串數組。

例如,我們可以這樣寫:

  1. const p = document.querySelector('p'); 
  2. p.classList.add('foo'); 
  3. p.classList.add('bar'); 
  4. const classArr = [...p.classList]; 

上面 classArr 最終值為[“foo”, “bar”]。

一旦我們將DOMTokenList轉換為一個數組,那么我們就可以使用任何數組方法來操作代碼。

總結

帶有 || 操作的長條件語句,我們使用對應數組方法來進行優化。

要操作多個類名,我們應該使用作為DOM元素對象一部分的classList屬性。通過這種方式,我們可以添加、刪除和切換類,而不需要操作字符串并自己將其設置為className屬性。

John Au-Yeung 來源:medium 譯者:前端小智

 

原文:https://levelup.gitconnected.com/javascript-refactoring-tips-making-functions-clearer-and-cleaner-c568c299cbb2

本文轉載自微信公眾號「 大遷世界」,可以通過以下二維碼關注。轉載本文請聯系 大遷世界公眾號。

 

責任編輯:武曉燕 來源: 大遷世界
相關推薦

2020-06-10 08:37:21

JavaScript重構技巧

2020-06-09 09:13:12

JavaScript重構對象

2022-04-21 07:20:39

Javascript重構邏輯

2020-06-01 08:42:11

JavaScript重構函數

2020-05-27 09:30:52

JavaScript重構函數

2019-06-27 10:35:40

JavaScript條件式匹配條件

2022-07-04 08:51:43

條件語句JavaScript

2020-08-21 17:40:15

JavaScript開發 技巧

2011-06-09 15:27:01

JavaScript

2010-10-08 09:42:23

JavaScript方

2011-06-03 13:48:18

JavaScript重構

2021-09-29 06:03:37

JavaScriptreduce() 前端

2020-02-27 09:55:46

開發技能代碼

2022-11-28 23:48:06

JavaScript編程語言技巧

2009-07-08 17:42:26

this屬性

2017-03-06 20:39:41

整潔代碼Clean Code

2023-09-05 08:00:00

開源GreptimeDB

2020-05-18 10:52:00

前端JavaScript html

2023-11-23 11:37:13

JavaScript數組

2020-12-17 07:52:38

JavaScript
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 毛片久久久 | 国产高清免费视频 | 在线第一页 | 欧美精品1区2区3区 免费黄篇 | 麻豆精品久久久 | 中文字幕av中文字幕 | 午夜在线视频一区二区三区 | 国产精品美女久久久久久久网站 | 欧美日韩国产高清 | 91偷拍精品一区二区三区 | 中文字幕免费视频 | 国产日韩欧美在线 | 中文字幕一区二区三区乱码在线 | 日韩中文字幕在线观看 | 一级毛片视频 | 天天操天天插 | 欧美影院| av一二三区| 亚洲精品第一国产综合野 | 久久午夜电影 | 丁香一区二区 | 黄色片在线 | 国产黄色在线观看 | 婷婷五月色综合香五月 | 欧美日本在线 | 99视频免费播放 | 欧美日韩一区二区在线观看 | 亚洲一区中文字幕在线观看 | 精品国产伦一区二区三区观看方式 | 亚洲精品视频在线 | 美女逼网站 | 亚洲高清视频一区二区 | 黄色一级电影在线观看 | 综合中文字幕 | 粉嫩粉嫩芽的虎白女18在线视频 | 日韩中文字幕在线免费 | 欧美性极品xxxx做受 | 久久综合色综合 | 久久久久久久久久久爱 | 99热精品国产 | 国产欧美日韩精品一区二区三区 |