10 个你可能还不知道的很酷JavaScript特性

2024-01-16 06:18

本文主要是介绍10 个你可能还不知道的很酷JavaScript特性,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

d8d34f26ca0e6600534af63a19c535e8.png

英文 | https://javascript.plainenglish.io/5-cool-javascript-features-you-might-not-know-about-yet-f2fc818bdd31

翻译 | 杨小爱

您可能使用 JavaScript 很长时间了,它的最新版本是 ES12。您可能正在使用它的一些功能,今天,我想重点介绍其中的一些功能,它们可能有助于您编写更好、更清晰、更优的 JavaScript 代码。

1、空运算符

如果左侧为空或未定义,则此运算符返回右侧值。

const data= null ?? 'data';
console.log(data);
// expected output: "data"
const data1 = 1 ?? 4;
console.log(data1);
// expected output: 1

逻辑 OR (||) 运算符执行相同的操作,但是,当将 0 作为值传递时,它将视为 false,这使得它容易用于数字。

function add(a, b) {val1 = a || 1;val2 = b || 1;sum = val1 + val2;return sum;
}console.log(add(0, 0)); //output:2

当我们使用 Nullish 运算符时,同样的事情

function add1(a, b) {val1 = a ?? 1;val2 = b ?? 1;sum = val1 + val2;return sum;
}console.log(add1(0, 0)); //ouput:0

2、Switch 语句优化

如果你想优化你的 switch 语句,那么,这个语句会有所帮助。

// Longhand
switch (data) {case 1:data1();break;case 2:data2();break;case 3:data();break;// And so on...
}
// Shorthand
var data = {1: data1,2: data2,3: data
};
const val = 1
data[val]();
function data1() {console.log("data1");
}
function data2() {console.log("data2");
}
function data() {console.log("data");
}

3、控制台样式

您是否厌倦了使用相同的控制台?现在我们可以设计我们的控制台。

console.log(`%cabc`, 'font-weight:bold;color:red');

4、AND (&&) 运算符

如果我们想避免一个 if 语句,那么这个速记会很有帮助。

//Longhand 
if (test1) {callMethod(); 
}
//Shorthand 
test1 && callMethod();

5、短函数调用

我们可以使用三元运算符来实现这些功能。

// Longhand
function data1() {console.log('data1');
};
function data2() {console.log('data2');
};
var data3 = 1;
if (data3 == 1) {data1();
} else {data2();
} //data1
// Shorthand
(data3 === 1 ? data1 : data2)(); //data1

6、返回简写

这将有助于避免大量代码专门返回到基于返回语句的调用方法。

// Longhand
let value;
function returnMe() {if (!(value === undefined)) {return value;} else {return callFunction('value');}
}
var data = returnMe();
console.log(data); //output value
function callFunction(val) {console.log(val);
}
// Shorthand
function returnMe() {return value || callFunction('value');
}

7、 If... else 简写

当我们有 if-else 语句时,这会有所帮助(确保您有最多 2-3 个 if...else 语句,因为多于这些会降低代码的可读性)。

// Longhand
let mychoice: boolean;
if (money > 100) {mychoice= true;
} else {mychoice= false;
}
// Shorthand
let mychoice= (money > 10) ? true : false;
//or we can use directly
let mychoice= money > 10;
console.log(mychoice);

嵌套条件如下所示:

let salary = 300,
checking = (salary > 100) ? 'greater 100' : (x < 50) ? 'less 50' : 'between 50 and 100';
console.log(checking); // "greater than 100"

8、可选链

有时,访问未定义的属性会出错,我们需要为所有嵌套对象属性添加空检查。可以使用可选链接来减少它。

const data = {a: 1,b: 'atit',d: {test1: {test2: 'patel',},},
};
console.log(data.val.test1); // here val is not present in object which leads the error
Error: Cannot read properties of undefined (reading 'test1')
console.log(data?.val); // using this we can check if the val is present in the data or not

9、对象属性赋值

当我们想从两个字符串创建对象并保持与字符串相同的键时,可以使用这个技巧来完成。

let data1 = 'abcd'; 
let data2 = 'efgh';
//Longhand 
let data = {data1: data1, data2: data2};
//Shorthand 
let data = {data1, data2};

10、延迟

当 JavaScript 代码量增加时,可能会导致浏览器必须等到所有脚本都执行完后再加载 DOM,从而增加了等待时间。

通过使用这个属性,我们可以告诉浏览器不要等待脚本;相反,它将继续构建 DOM,并在后台加载脚本。

<p>heading before loads</p>
<script defer src="src/test.js"></script>
<p>heading after loads</p>

总结

以上就是我今天与你分享的10个关于JavaScript 技巧的知识,希望能够有助于您的代码看起来更好,并帮助您在 JavaScript 中编写更清晰的代码。

感谢你的时间,谢谢阅读。

学习更多技能

请点击下方公众号

98c7faf9dfafc6296b9da95378516470.gif

6a4b6a96398c596719a8ef354ee2dcaa.png

e99791df06f875ac513b5302e06ad330.png

这篇关于10 个你可能还不知道的很酷JavaScript特性的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/611571

相关文章

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见

Java注解之超越Javadoc的元数据利器详解

《Java注解之超越Javadoc的元数据利器详解》本文将深入探讨Java注解的定义、类型、内置注解、自定义注解、保留策略、实际应用场景及最佳实践,无论是初学者还是资深开发者,都能通过本文了解如何利用... 目录什么是注解?注解的类型内置注编程解自定义注解注解的保留策略实际用例最佳实践总结在 Java 编程

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B