热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

7个我最常用的JavaScript实用程序函数

英文|https:javascript.plainenglish.iomy-7-most-used-javascript-utility-functions-86afd61ad76

2fcbda77f0ca943040b1c2a42bd61f63.jpeg

英文 | https://Javascript.plainenglish.io/my-7-most-used-Javascript-utility-functions-86afd61ad76c

Javascript 实用程序函数是有用的、可重用的片段,你可以在许多不同的项目中重用它们。它们的目的是为常见任务提供一致且有效的答案,并帮助提高代码的一致性。

在本文中,我想重点介绍我在许多项目中使用的 7 个实用函数并解释它们的用途。

1.将数字转换为货币

在 Javascript 中处理货币时,事情会变得复杂。特别是当你需要处理显示不同类型的货币时。

Javascript 提供了 Intl.NumberFormat 对象,它允许你以对语言敏感的方式格式化数字。它提供的选项之一是将数字格式化为货币。

该函数接受 3 个参数:

  • num - 要格式化的数字。

  • currency——要格式化的货币——默认设置为“欧元”,因为我主要需要处理基于欧元的价格。

  • locale — 默认设置为“nl-NL”,因为我经常处理显示为荷兰的价格。

你可以使用下面 CodePen 中的值。例如,你会看到将语言环境更改为“en-US”会将十进制表示法从逗号更改为点。

function convertToCurrency(num, currency = 'EUR', locale = 'nl-NL') {const formatter = new Intl.NumberFormat(locale, {style: 'currency',currency: currency});return formatter.format(num);
}

2. 将 HTML 字符串转换为 DOM 对象

在很多情况下,你可能会收到 HTML 字符串而不是 HTML 元素。例如,当接收来自 API 的 JSON 响应中的 HTML 或通过 Nunjucks 之类的模板解析器呈现模板时。

你可以通过 innerHTML 属性将此 HTML 字符串直接注入到 dom 中,但有时你希望将此字符串转换为 HTML 对象以进行额外的转换、验证或更具体的 DOM 注入。

该函数接受 2 个参数:

  • content — 要转换为对象的 HTML 字符串。

  • selector——你想要接收的选择器——DOMParser 对象将创建一个完整的 HTMLObject,包括一个 和 标记。如果你只想要某个元素,你可以传入选择器,例如“section”,你将收到该元素。

function parseStringAsHtml(content,selector
) {const domParser = new DOMParser();const parsed = domParser.parseFromString(content, 'text/html');return parsed.querySelector(selector);
}

3.去抖

在 Javascript 中,debounce 函数将确保你的函数只会在每次用户输入时触发一次,或者在等待参数中指定的时间段内至少触发一次。

例如,假设我们想根据搜索查询向用户显示建议,我们可以在用户输入时显示建议并在输入每个字母后刷新,但这可能会让用户感到烦恼。通常在输入一个键后等待至少 300 毫秒以显示建议以确保用户完成输入。

这个函数有 3 个参数:

  • fn - 要执行的函数。

  • wait — 函数执行前的等待时间。

  • immediate — 一个布尔值,指示第一次调用函数时是否应立即调用。

function debounce(fn, wait, immediate) {let timeout;return function setDebounce(...args) {const later = () => {timeout = null;if (!immediate) {fn.apply(this, args);}};const callNow = immediate && !timeout;clearTimeout(timeout);timeout = setTimeout(later, wait || 200);if (callNow) {fn.apply(this, args);}};
}

4. 日期验证

有时,你从代码、用户输入或 API 中的某处收到日期字符串,你将其转换为日期对象并尝试编辑或显示日期并收到日期无效的错误。

使用这个简单的实用方法,你可以验证新构建的日期对象是否实际上是有效的日期对象。

function isDateValid(date) {return !Number.isNaN(date.getTime());
}

5. 将 FormData 转换为 JSON

创建 FormData 对象时,有时将其转换为类似 JSON 的对象很有用。例如,当你向其发布数据的 API 只接受 JSON 请求时,它不接受任何内容。

在大多数情况下,一个 FormData 对象可以很容易地映射到一个对象,但是在处理多选复选框时,事情会变得混乱。由于每个复选框都具有相同的名称,因此对象的键值对将相互覆盖。

这个简单的实用方法为FormData 转换为一个对象,并确保将多选值映射到一个数组,而不是每次都覆盖该值。

function convertFormdataToJsonObject(formData) {const data = {};for (const [key, value] of formData.entries()) {if (Object.prototype.hasOwnProperty.call(data, key)) {const oldValue = data[key];if (!Array.isArray(data[key])) {data[key] = [];data[key].push(oldValue);}data[key].push(value);continue;}data[key] = value;}return data;
}

6. 衡量一个函数的性能

有时你想知道你的应用程序的哪一部分正在减慢你的网站速度,调试函数的执行时间很有用。

幸运的是,浏览器提供了本地支持来帮助你计算这一点。但不是将这些控制台方法添加到每个函数中,而是每次都想测试,你可以简单地调用这个有用的实用程序方法。

此函数需要 2 个或更多参数:

  • name — 标签的名称显示在控制台中。

  • fn - 您要衡量其性能的函数。

  • 任何附加参数——你正在调用的函数的参数。

function measurePerformance(name, fn, ...args) {if (typeof fn !== "function") {console.error(`Provide a valid function, ${typeof fn} provided`)return;}console.time(name)fn.bind(this, ...args);console.timeEnd(name)
}

7.从数组中删除重复项

我经常发现自己需要从数组中删除可能的重复项。此方法只是在将数组转换为 Set 并返回后返回一个新数组。

集合是一个简单的对象,它存储只能出现一次的值,使其成为对数组进行重复数据删除的简单方法。

function removeDuplicates(array) {if (!Array.isArray(array)) {console.error(`array expected, ${typeof array} provided`)return}return [...new Set(array)]
}

结论

我希望其中有一些实用方法对你有用, 也希望你能从中学到新知识,如果你觉得有帮助的话,请点赞我,关注我,并将它分享给你的朋友,也许能够帮助到他。

最后感谢你的阅读,祝编程愉快!

学习更多技能

请点击下方公众号

87a39238c1c5404cd3fd525143b2a6b6.gif

2a2b012f3faecc5552996b9755268c2c.jpeg

9119598aa9bf6aa739db6a9ab8f34887.png


推荐阅读
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • 本文介绍了设计师伊振华受邀参与沈阳市智慧城市运行管理中心项目的整体设计,并以数字赋能和创新驱动高质量发展的理念,建设了集成、智慧、高效的一体化城市综合管理平台,促进了城市的数字化转型。该中心被称为当代城市的智能心脏,为沈阳市的智慧城市建设做出了重要贡献。 ... [详细]
  • 本文介绍了九度OnlineJudge中的1002题目“Grading”的解决方法。该题目要求设计一个公平的评分过程,将每个考题分配给3个独立的专家,如果他们的评分不一致,则需要请一位裁判做出最终决定。文章详细描述了评分规则,并给出了解决该问题的程序。 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • 如何在服务器主机上实现文件共享的方法和工具
    本文介绍了在服务器主机上实现文件共享的方法和工具,包括Linux主机和Windows主机的文件传输方式,Web运维和FTP/SFTP客户端运维两种方式,以及使用WinSCP工具将文件上传至Linux云服务器的操作方法。此外,还介绍了在迁移过程中需要安装迁移Agent并输入目的端服务器所在华为云的AK/SK,以及主机迁移服务会收集的源端服务器信息。 ... [详细]
author-avatar
落地有声800_491_431
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有