JavaScript 中有趣的 9 个常用编码套路

news2024/11/25 22:51:41

 

大厂面试题分享 面试题库

前后端面试题库 (面试必备) 推荐:★★★★★

地址:前端面试题库  web前端面试题库 VS java后端面试题库大全

我今天仔细研究了一下掘金上的热门文章数据和内容。我发现你们真是热衷于学习,喜欢那些能够节省时间的代码小窍门,喜欢罗列技巧的1、2、3、4的这类简洁直观的技巧。

也许今天我应该做出一个与祖宗相悖(同流合污)的决定,尝试将我们编程或者阅读源码的过程中遇到的一些非常有趣的技巧列出来,供大家学习和收藏。😄

这篇文章是面向新手的,但如果幸运的话,希望能给各位大佬们带来一些小小的启发。

1️⃣ set对象:数组快速去重

常规情况下,我们想要筛选唯一值,一般会想到遍历数组然后逐个对比,或者使用成熟的库比如lodash之类的。

不过,ES6带来了一个新玩意儿!它引入了一个全新的对象类型:Set!而且,如果结合上...展开运算符,我们可以超级快速地创建一个已经去重的全新数组!😎

const arr = [10, 10, 10, 20, 20, 30, 40, 40, 50, 60, 60, 70];
const uniArr = [...new Set(array)];
console.log(uniArr);
// [10, 20, 30, 40, 50, 60, 70]

这个技巧只适用于包含基本类型的数组,比如undefinednullbooleanstringnumber

但是要记住哦,如果数组里面还有对象、函数或其他数组的话,就不能用这个方法了!🚨

2️⃣ include方法:简化( || 或)条件判断

当我们使用逻辑运算符||进行条件判断时,如果有很多可选值,代码会变得冗长。

不过,我们可以使用includes方法来简化对数组的遍历操作,方便地判断数组是否包含某个特定的元素。

这样一来,我们就可以更简洁地列出可选值,而不必写一长串的条件判断语句。includes方法可以帮助我们轻松判断数组中是否存在指定的元素🔎🎯

const myNum = '3';
const numArr = ['1', '2', '3'];
​
// 使用 || 
if (myNum === '1' || myNum === '2' || myNum === '3') {
    //……
}
​
// 使用 include
if (numArr.includes(myNum)) {
    //……
}           

3️⃣ 截断数组:改变length就可以

操作数组时,我们通常会优先使用array对象中的高级函数。

不过,我这里要介绍一种更简单的方法来改变数组长度,我喜欢它的原因是它非常直观且易读。

只需使用length属性并传递一个数字,就可以改变数组的长度。这样做非常方便!😊

let array = ['1', '2', '3', '4'];
array.length = 2;
console.log(array); // ['1', '2']

当然 ,如果你更注重性能,还是请使用 array.slice()

4️⃣ 数字分割符: 提高数字可读性

若要提高数字的可读性,你可以使用下划线作为分隔符来更好地区分数字的各个部分。这样做可以让数字更易读,让人一目了然🔢💡

const num = 1_000_000_000;
​
console.log(num); // 1000000000

5️⃣ 控制台打印:用对象包裹更清晰

在使用console.log()时,你可以将参数括在大括号中,这样可以在控制台输出时同时显示变量的名称和值。这种方式非常方便,让你更清晰地了解每个变量的内容🔍💡

const name = "道长王jj";
console.log({ name });
​
// {
//     "name": "道长王jj"
// }

6️⃣ 短路运算:简化条件判断

if...else条件判断是代码过程中最常用的,几乎在任何情况下,我们都会快速地敲下它来控制逻辑流程。

不过,有时候我们也希望代码更加简洁、快速,不占那么多篇幅。我们想尽可能地简洁且快速,于是就会用到三元运算符:

const num = 75;
const result1 = num > 100 ? '大于100' : '小于100';

但是我在这里并不是推荐使用“三元运算”,其实有时候三元运算符可能会让代码逻辑变得有点复杂哦!😅比如这样:

const result2 = num > 100 ? (num > 200 ? '大于200' : '介于100和200之间') : '小于100';

这个时候,使用 && 和 || 这类逻辑运算符反而能更简洁的表达算式。

举个例子:

// 假设,我们有三个已经打过分的相亲对象必须选择一个来当女朋友,使用 `&&` 可以很好的帮我们做出选择。
const one = 8;
const two = 9;
const three = 10;
// 返回10
console.log(one && two && three); 
// 返回0
console.log(0 && null); 
// 当然,如果你足够独特~~(变态)~~,就是不要女朋友,如果选只选最差的,你可以使用 `||` 来帮你做吹选择。
const one = 8;
const two = 9;
const three = 10;
// 返回8
console.log(one || two || three); 
// 返回null
console.log(0 || null); 

哦,这个情况在工作场景中确实很常见。

假设我们想返回变量的 length ,但我们不确定接口会不会给我们需要的类型。

这个时候我们就可以使用 if/else 语句来检查是可接受的类型,但它会让我们的代码非常臃肿。

这时候,我们可以使用短路运算来简化代码,而且有极高的健壮性:

// 使用if
let temp = getArray();
​
if (!temp) {
    tempLength = 0;
} else {
    tempLength = temp.length
}
​
// 使用 ||
// 如果变量 tempArray 为真,则将返回该变量。否则,将返回 []
const temp = (tempArray || []).length;

7️⃣ 可选链:更加安全地访问对象属性

你有没有遇到过访问嵌套对象属性的困扰?

就是有时候你根本不确定这个对象或者它的子属性到底存不存在,结果就报错了!😩以至于程序崩溃无法运行

console.log(abc.ss)
// ceError: abc is not defined
//     at <anonymous>:1:1
// (匿名) @ VM190795

为了不让报错阻止我们的程序运行,我们通常会将它包装在一个if……else代码块中:

if (abc.ss) {
  console.log(abc.ss);
} else {
  console.log('没有abc这个变量喏~');
}
​
// 还可以用短路运算
console.log(abc && abc.ss)

不过,ES6可选链可以让我们彻底抛弃掉上面的写法了,我们可以直接这样做:

console.log(abc?.ss?.aa?.bb?.cc)

8️⃣ 巧用运算符:快速类型转换

在这之前需要科普一些小知识:

除了常规的truefalse之外,其他变量也可以被当成true 或者 false

除了0""(空字符串)nullundefinedNaNfalse 之外呢,JavaScript中的所有其他值都是"真的"哦!

所以呢,基于这个认知。

我们可以使用负运算符 ! ,将类型转换为 "boolean" 。

const x = Boolean(expression);     // 推荐
const x = !!(expression);          // 推荐
const x = new Boolean(expression); // 不太好

我们可以使用连接运算符 + 后跟一组空引号 '',将类型转换为 "string" 。

const value = 12 + '';
console.log(value); // '12'

我们可以使用减法运算符 -,将类型转换为 "number" 。

感谢 指正,我之前这里使用了加法运算符。

let myValue = '12';
myValue = myValue - 1;
console.log(myValue); // 11
​
// 当然也可以转换 Boolean 变成 Number 
// 工作中不推荐这样用!!!!
console.log(+true); // 1
console.log(+false); // 0

9️⃣ 快速运算:更快更简洁的数学运算操作符

以前我们在使用JavaScript进行数学运算时,总是要借助Math库进行运算。

很奇怪的是,但是很多教程并没有提醒我们,ES7其实带来的全新运算符✨

如果想示乘方操作,通常我们会调用Math.pow(5, 7)这个方法。但是现在我们可以使用幂运算符**了,而且性能更快更好。

console.log(5 ** 7); // 78125

如果想将浮点数转换为整数,通常我们会使用Math.floor()Math.ceil()Math.round()这些方法。不过,其实可以使用 | 将浮点数直接截断为整数。这个技巧可以让你的代码更简洁高效哦!🚀

// 正数,则向下舍入
console.log(34.9 | 0);  // Result: 34
// 负数,则向上舍入
console.log(-12.9 | 0); // Result: -12

以前我们只取千分位需要进行类型转换后才能进行取数

let str = "33545"; 
Number(str.substring(0, str.length - 3)); // 33

但是我们可以更优雅地这样做:

console.log(33545 / 1000 | 0)  // Result: 33

🎉 希望本文能够帮助到你, 虽然真的很基础很基础。如果你有任何疑问或者想进一步讨论相关话题,请随时告诉我。🚀✨

 大厂面试题分享 面试题库

前后端面试题库 (面试必备) 推荐:★★★★★

地址:前端面试题库  web前端面试题库 VS java后端面试题库大全

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/704956.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

#10045. 「一本通 2.2 练习 1」Radio Transmission(内附封面)

[BOI2009] Radio Transmission 无线传输 题目描述 给你一个字符串 s 1 s_1 s1​&#xff0c;它是由某个字符串 s 2 s_2 s2​ 不断自我连接形成的&#xff08;保证至少重复 2 2 2 次&#xff09;。但是字符串 s 2 s_2 s2​ 是不确定的&#xff0c;现在只想知道它的最短长度…

springboot流浪动物救助系统-计算机毕设 附源码78174

springboot流浪动物救助系统 摘 要 21世纪的今天&#xff0c;随着社会的不断发展与进步&#xff0c;人们对于信息科学化的认识&#xff0c;已由低层次向高层次发展&#xff0c;由原来的感性认识向理性认识提高&#xff0c;管理工作的重要性已逐渐被人们所认识&#xff0c;科学…

目标检测算法-YOLOV8解析(附论文和源码)

目标检测算法-YOLOV8解析&#xff08;附论文和源码&#xff09;

LeetCode刷题 | 300. 最长递增子序列、674. 最长连续递增序列、718. 最长重复子数组

300. 最长递增子序列 给你一个整数数组 nums &#xff0c;找到其中最长严格递增子序列的长度。 子序列 是由数组派生而来的序列&#xff0c;删除&#xff08;或不删除&#xff09;数组中的元素而不改变其余元素的顺序。例如&#xff0c;[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的子…

地图可视化开发的平台如何选择?

地图数据的日益丰富和人们对数据可视化需求不断提高&#xff0c;地图可视化已经成为了信息化建设中重要的组成部分&#xff0c;在各个行业和领域中都有广泛的应用。地图可视化开发平台选择至关重要&#xff0c;不仅会影响到可视化效果&#xff0c;还会影响到开发难度、维护成本…

我国没有根服务器,那么别人可以控制中国的网络吗?

服务器没想象的那么重要。 根服务器简单理解就是一个密码对应一个访问地址。 就像小时候座机电话刚兴起的时候&#xff0c;那时候给有座机的每家都会发一个全市各部门的联系电话的通讯录。 而发布这个电话通讯录的地方就类似根服务器的作用。 然后每家都自己弄一本一样的&am…

AMEYA360:太阳诱电导电性高分子混合铝电解电容器

太阳诱电导电性高分子混合铝电解电容器&#xff0c;最适合需要大容量和高耐压的车载装置和产业设备。电解质使用导电性高分子和电解液&#xff0c;兼具高性能和高可靠性&#xff0c;满足客户需求。 混合结构在阳极箔表面生成电介质(氧化铝)。用隔膜隔开阳极箔与阴极箔&#xff…

Python基础教程:Turtle绘制图形

前言 在Python中&#xff0c;绘图是一个非常有趣的领域。其中比较流行的绘图库就有 Turtle。Python Turtle模块是一个基于Tkinter图形库的绘图工具&#xff0c;Turtle库可以让你在一个窗口中创建和操纵它的画布&#xff0c;通过学习Turtle库的使用&#xff0c;刚好可以为提供了…

python3开发-AI智能联系人管理系统

目录 背景 1. 数据收集与存储&#xff1a; 2. 搜索与过滤&#xff1a; 3. AI智能功能&#xff1a; 4. 用户界面与交互&#xff1a; 5. 数据备份与恢复&#xff1a; 6. 安全与权限管理&#xff1a; 7. 测试与部署&#xff1a; 代码示例 1. 数据收集与存储&#xff08;…

基于Java+Swing+Mysql物流跟踪管理系统

基于JavaSwingMysql物流跟踪管理系统 一、系统介绍二、功能展示1.主页2.新增物流信息3.删除物流信息 三、数据库四、其他系统实现五、获取源码 一、系统介绍 该系统实现了查看物流列表、新增物流信息、删除物流信息 运行环境&#xff1a;eclipse、idea、jdk1.8 二、功能展示…

字节码原理浅析 —— 基于栈的执行引擎

概要 字节码是运行在 JVM 上的&#xff0c;为了能弄懂字节码&#xff0c;需要对 JVM 的运行原理有所了解。这篇文章将以栈帧为切入点理解字节码在 JVM 上执行的细节。 虚拟机 虚拟机常见的实现方式有两种&#xff1a;Stack based 的和 Register based。比如基于 Stack 的虚拟机…

一次线上事故,我顿悟了异步的精髓

在高并发的场景下&#xff0c;异步是一个极其重要的优化方向。 前段时间&#xff0c;生产环境发生一次事故&#xff0c;笔者认为事故的场景非常具备典型性 。 写这篇文章&#xff0c;笔者想和大家深入探讨该场景的架构优化方案。希望大家读完之后&#xff0c;可以对异步有更深…

Linux 环境变量 命令行参数

文章目录 问题引入环境变量环境变量相关操纵&#xff08;附源码&#xff09;命令行参数问题解释 问题引入 Linux下&#xff0c;为什么我们自己写的可执行文件需要写明路径才可以执行&#xff0c;而系统的命令不需要&#xff1f; 如何使自己的命令也可以不带路径执行&#xff…

MioIO笔记01

视频地址&#xff1a;分布式文件系统MinIO教程&#xff0c;2021最新版【通俗易懂】_哔哩哔哩_bilibili 目录 1【分布式文件存储系统Minio实战】 P001【1.课程介绍】05:08 P002【2.Minio优点和基础概念】19:29 P003【3.Minio的EC码和文件存储结构】11:33 2【Minio环境搭建】…

【youcans动手学模型】ShuffleNet 模型

欢迎关注『youcans动手学模型』系列 本专栏内容和资源同步到 GitHub/youcans 【youcans动手学模型】ShuffleNet 模型 1. ShuffleNet 网络模型1.1 模型简介1.2 论文介绍 2. 在 PyTorch 中定义 ShuffleNet V1 模型类2.1 分组卷积与通道混洗2.2 ShuffleNet 单元2.3 自定义 Shuffle…

0、如何用运python成为顶级黑客

前言 黑客攻击可以导致个人、组织或公司的机密信息被窃取、破坏或泄露&#xff0c;造成财务损失、声誉受损、系统崩溃等各种问题 一、为什么Python编程语言适合网络安全工作&#xff1f; Python编程语言在网络安全工作中具有许多优势&#xff0c;以下是一些详细介绍&#xf…

性能测试中的随机数性能问题探索

目录 缘起 多线程 单线程 末了 总结&#xff1a; 在软件测试中&#xff0c;经常会遇到随机数。我简单分成了两类&#xff1a; 简单取随机数&#xff1b; 从一个集合中随机取值。 其实第二个场景包含在第一个场景内。对于接口测试来说&#xff0c;通常我们直接使用第二种…

springboot定时任务详解

文章目录 一、基于注解&#xff08;静态&#xff09;1、添加依赖2、创建定时任务3、参数说明 二、基于接口&#xff08;动态&#xff09;1、添加依赖2、添加数据库记录3、创建定时器4、启动测试 三、Quartz1、添加依赖2、编写任务类3、编写配置类4、启动项目 在我们开发项目过程…

css基础知识十四:什么是响应式设计?响应式设计的基本原理是什么?如何做?

一、是什么 响应式网站设计&#xff08;Responsive Web design&#xff09;是一种网络页面设计布局&#xff0c;页面的设计与开发应当根据用户行为以及设备环境(系统平台、屏幕尺寸、屏幕定向等)进行相应的响应和调整 描述响应式界面最著名的一句话就是“Content is like wat…

AD20|原理图导入Pcb时三极管引脚报错 Unkown Pin:Pin Q1-B

完成原理图绘制后&#xff0c;将其导入到Pcb中进行布局时&#xff0c;出现报错;Unknown Pin: Pin Q1-B. 原因是&#xff1a;引脚名称不一致 在原理图中&#xff0c;三个引脚分别定义B、C、E&#xff1b; 而在常见的TO—92A封装中&#xff0c;使用1、2、3作为三个引脚的名称&am…