百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

JavaScript重构技巧—数组,类名和条件

liuian 2024-12-30 05:16 45 浏览

JavaScript 是一种易于学习的编程语言,编写运行并执行某些操作的程序很容易。然而,要编写一段干净的JavaScript 代码是很困难的。

在本文中,我们学习如何使用数组来代替条件语句,以及如何使用classList操作类名。

用数组检查替换长表达式

平时开发中,我们可能会写如下的代码:

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

对于上面,我们可以使用一些数组方法来减少条件表达式的长度。

一种方法是使用数组的include方法:

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

如果传递给参数的值包含在数组实例中,include方法返回true,否则返回false。

另一种方法是使用数组的some方法:

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

通过some方法,我们可以检查回调中是否存在具有给定条件的数组元素。

如果存在一个或多个,则返回true,否则返回false。

在 DOM 元素中使用 classList 属性

检查 DOM 元素中是否存在类并操作多个类的最简单方法是使用classList属性。

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

const p = document.querySelector('p');
p.classList.add('foo');
p.classList.add('bar');
p.classList.add('baz');

这样,我们可以添加多个类而无需操作字符串。我们只是获得DOM元素对象的classList属性,然后调用add通过将带有类名的字符串传递到add方法中来添加类。

现在,渲染的DOM元素具有foo,bar和baz类。

同样,我们可以调用classList属性的remove方法,该方法使用一个带有要删除的类名的字符串来删除该类。

例如,我们可以这样写:

const p = document.querySelector('p');
p.classList.add('foo');
p.classList.add('bar');
p.classList.add('baz');
p.classList.remove('baz');

要检查 DOM 元素对象中是否存在类名,可以使用contains方法。

例如,我们可以这样写:

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

上面判断 p 元素是否包含 baz 类,因为 p 没有包含 baz类,所以返回 false。

classList属性还有toggle方法,表示切换类(添加或者移除),例如下面的代码:

const p = document.querySelector('p');
const button = document.querySelector('button');
p.classList.add('foo');
p.classList.add('bar');

button.onclick = () => {
  p.classList.toggle('bar');
}

每点击一次按钮,p 的上 bar 类就会添加或者移除。

clasList属性有一个类似数组的可迭代对象,称为DOMTokenList对象。因此,我们可以使用展开操作符将其转换为数组,将clasList转换为一个带有类名的字符串数组。

例如,我们可以这样写:

const p = document.querySelector('p');
p.classList.add('foo');
p.classList.add('bar');
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

相关推荐

window7下载安装(windows7下载安装)

要安装Windows7,首先需要购买合法的Windows7安装光盘或者从官方网站下载安装文件。然后,插入安装光盘或者打开下载的安装文件,重启电脑,在启动时按照屏幕提示进入安装界面。在安装界面中,按照指...

自己装win7系统(自己装win7系统教程)

以64位系统为例:1、首先,下载好win7系统的镜像文件。2、我们需要下载win7x64的压缩包到电脑。3、下载完成后,解压压缩包,解压出来的文件不要放在C盘。我们可以看到一个x64的gho镜像,一...

win10专业版关闭防火墙(win10专业版防火墙在哪里设置)

你可以按照以下步骤关闭Windows10专业版的防火墙:1.点击“开始”按钮,然后选择“设置”。2.在设置窗口中,选择“更新和安全”。3.选择“Windows安全中心”,然后在右侧窗格中选...

系统一键重装官网(正版一键重装系统)
  • 系统一键重装官网(正版一键重装系统)
  • 系统一键重装官网(正版一键重装系统)
  • 系统一键重装官网(正版一键重装系统)
  • 系统一键重装官网(正版一键重装系统)
联想笔记本电脑哪款好用又便宜

联想笔记本电脑中便宜的型号非常多,其中包括IdeaPad314、IdeapadS145、ThinkPadE14等等。这些笔记本电脑都有不错的性能和基础配置,而且价格相对于其他品牌的同类产品更加...

win7 网卡驱动(win7网卡驱动代码31)

以下是安装Win7网卡驱动的步骤:1.打开设备管理器。方法是按下Win+R快捷键,输入“devmgmt.msc”命令并点击“确定”按钮。2.展开“网络适配器”选项,找到你要安装驱动的网卡型号。3....

windows资源管理器已停止工作弹窗

解决方法如下:1、首先使用键盘组合快捷键“Ctrl+Alt+Del(.)”打开任务管理器;2、打开后查看进程中是否含有“explorer.exe”项,若没有单击左上角“文件”选项,单击“新建任务”;3...

怎么设置从u盘启动系统(设置从u盘启动盘步骤)

1、插上U盘,启动电脑,按照说明书上的步骤进入bios选项。一般是开机时按住F2/F12/del/home/等按键。2、选择到boot自选项,几乎所有的主板都是在这里配置启动顺序的。利用键盘上的上下...

u启动和u深度哪个好(u深度启动u盘安装win7系统教程)

关于这个问题,是的,"u深度"和"u启动"是两个不同的概念。"u深度"通常指的是深度神经网络(DeepNeuralNetwork,DNN)的层数或...

amd历代cpu型号大全(amdcpu历史)

 AMDCPU型号。速龙,迅龙,r5,r7.型号不同价格,有比较大的区分,比如r5,5600,r55600X.r75700,5800,r715700X5800x.无论是核心个数还有核心...

oracle认证(oracle认证等级划分)

Oracle认证分为OCA,OCP,OCM。OCA:报考OCA的基础条件是报考OCA不限制考生的文凭,任何人都可以报考并获得此证书;对OCA有一定的了解。。其证书拥有者在全球各地将享有OCA相关专业免...

惠普打印机官网怎么下载驱动

HP惠普打印机驱动官网是存在的。因为HP惠普是一家著名的电脑及相关产品制造商,他们会提供各种驱动程序和软件以保证设备的兼容性和稳定性。HP惠普打印机驱动官网可以通过搜索引擎查找,也可以通过HP惠普的官...

win7怎么启用系统还原(win7系统还原功能怎么开启)

在Windows7中,您可以按照以下步骤启用或关闭系统还原:1.单击开始菜单,右键单击“计算机”(或“我的电脑”),然后选择“属性”。2.单击“系统保护”链接,然后在弹出的“系统属性”对话框...

wpsoffice(wpsoffice功能栏全是灰色的怎么恢复)

wpsoffice是金山公司开发的一款国产办公软件,有WPS文字、WPS表格和WPS演示三个板块。其作用就是办公应用。1、WPSOFFICE:WPSOffice是由金山软件股份有限公司自主研发的一...

如何清理c盘中不必要的文件(如何清理c盘中不必要的文件夹)
  • 如何清理c盘中不必要的文件(如何清理c盘中不必要的文件夹)
  • 如何清理c盘中不必要的文件(如何清理c盘中不必要的文件夹)
  • 如何清理c盘中不必要的文件(如何清理c盘中不必要的文件夹)
  • 如何清理c盘中不必要的文件(如何清理c盘中不必要的文件夹)