JavaScript单行技巧:高效处理数据

开发 前端
今天我们介绍有一些关于JavaScript的有趣的事情,大多数开发人员可能都没这样使用过。下面程序中,我从17行命令行转换到一个单行的功能语句。

本文翻译自 10 one-liners that will change how you think about JavaScript forever,作者:Tari Ibaba, 略有删改。

本文介绍JavaScript单行程序的独特数据处理能力,单行技巧可以帮助我们更简洁、更高效地处理数据。这些技巧不仅提升了代码的可读性,也减少了代码行数,使代码更加紧凑。以下是一些JavaScript单行技巧,用于高效处理数据,附带相应的代码示例。

图片图片

像这样令人惊叹的单行程序显示了您对语言的掌握及其独特的数据处理能力。️

今天我们介绍有一些关于JavaScript的有趣的事情,大多数开发人员可能都没这样使用过。

下面程序中,我从17行命令行转换到一个单行的功能语句。

图片图片

转换后:

图片图片

转换后的代码相对要清晰优雅,你可以清楚地看到数据是如何从输入到输出。

求一组数字的平均值

通过reduce将数组的总和除以它的长度,我们可以计算出数字的平均值。

const average = array => array.reduce((total, num) => total + num, 0) / array.length;

将URL的查询字符串部分转换成对象

这个示例展示了如何将查询字符串转换成对象。URLSearchParams会解析字符串,并返回一个可迭代的对象,之后通过Object.fromEntries将其转换为对象,使得URL参数的检索更加便捷。

const query = 'name=XXX&age=18';

// 将字符串解析为对象
const parseQuery = query => Object.fromEntries(new URLSearchParams(query));

// 结果: parseQuery = { name: 'XXX', age: '18' }

将秒数转换为时间格式的字符串

此示例展示了秒数到 HH:MM:SS 字符串的转换过程。通过创建一个 Date 对象,并根据秒数设置其时间值,最后格式化输出。

const seconds = 9000; // 一小时是 3600 秒,多出 61 秒

const toTimeString = seconds => new Date(seconds * 1000).toISOString().substr(11, 8);

toTimeString(seconds);  // '02:30:00'

反转字符串

图片图片

转换后:

图片图片

ID分组

按特定的对象属性对数组进行分组:

图片图片

使用示例:

图片图片

代码执行效果:

图片图片

生成随机UUID

这里有有基本算术、幂、随机值、方法、位移位、正则表达式、回调函数、递归、求幂……等一起工作。

图片图片

生成随机十六进制颜色

1行生成一个随机的十六进制颜色:

图片图片

数组相等

用一行代码检查数组是否相等。

❌ 11行:

图片图片

✅ 1行:

图片图片

✅ 或者:

图片图片

电子邮件

电子邮件验证都是关于正则表达式的:

图片图片

还有更全面的验证:

图片图片

图片图片

将JSON转换为map

图片图片

snake转换为camel case

轻松地从蛇式转换为骆驼式,无需临时变量。

图片图片

最后

将很多操作都集中在一个语句里;从输入到输出,不断地处理,流畅地进行各种操作。这就是JavaScript单行程序的强大之处。

责任编辑:武晓燕 来源: 南城大前端
相关推荐

2022-11-28 23:44:26

JavaScript技巧程序员

2023-08-27 16:19:09

JavaScript编程语言

2010-10-08 10:03:52

JavaScript图像

2023-03-13 16:08:00

JavaScript数组函数

2023-11-30 16:05:17

2024-06-24 00:05:00

Python代码

2024-04-09 14:27:39

2024-01-30 08:54:05

JavaScript技巧代码

2024-06-24 13:35:48

2024-09-06 17:32:55

字符串Python

2019-07-31 10:24:16

JavaScript浏览器口袋妖怪

2023-02-15 16:19:59

JavaScript技巧API

2022-10-20 15:16:23

JavaScript数组技能

2023-08-01 14:36:00

JavaScript开发

2023-10-16 07:55:15

JavaScript对象技巧

2024-06-04 07:46:05

2023-10-10 16:20:38

JavaScript代码技巧

2024-10-09 14:45:41

2023-10-23 15:02:53

JavaScript

2010-09-06 09:06:22

CSS
点赞
收藏

51CTO技术栈公众号