这些ES6用法你都会吗?

2024-09-08 15:28
文章标签 用法 frontend es6

本文主要是介绍这些ES6用法你都会吗?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一 关于取值

取值在程序中非常常见,比如从对象obj中取值

const obj = {
a:1
b:2
c:3
d:4
}

吐槽:

const a =  obj.a;
const b =  obj.b;
const c =  obj.c;
//或者
const f =  obj.a  +  obj.b;
const g =  obj.c  +  obj.d;

改进:用ES6解构赋值

const { a,b,c,d } = obj
const f = a +b
const h = c + d
// 如果想创建的变量名和对象的属性名不一致,可以这么写
const { a : a1 } = obj  //  a1 === a
// 注意结构对象不能为 undefined null ,否者会报错,故要给被结构对象一个默认值
const  { a,b,c,d } = obj || { }

二 关于合并数据

比如合并两个数组,合并两个对象

const  a = [ 1,2,3 ];
const b=[ 1,5,6 ];
const c = a.concat(b); // [ 1,2,3,1,5,6 ]
const obj1 ={a:1}
const obj2 = {b:1,}
const obj=0bject.assign( { },obj1,obj2 ); // { a:1,b:1 }

数组合并考虑去重, 改进: ES6扩展运算符

const a = [ 1,2,3 ];
const b=[ 1,5,6 ];
const c=[...newSet([...a,...b])]; // 用 new set 去重,[1,2,3,5,6]
const obj1 = {a:1}
const obj2 = {b:1,}
const obj = {...obj1,...obj2}; // {a:1,b:1}

三 关于拼接字符串的

const name ='小明';
const score =59;
let result =' ' ;
if(score >60){ 
result =`${name}的考试成绩及格`;
} else {
result= `${name}的考试成绩不及格`;
}

改进:ES6字符串模板${ }中可以放任意的JavaScript表达式,可以进行运算以及引用对象属性

const name ='小明';
const score =59;
const result = `${ name }${ score > 60 ? `的考试成绩及格` : '的考试成绩不合格' } `;

四 关于if中判断条件

if(
type == 1 ||
type == 2 ||
type == 3 ||
type == 4 ||
){
操作...
}

**改进: SE6中数组的实例方法includes **

const condition = [ 1,2,3,4 ];
if( condition.includes( type ) ) {
操作...
}

关于列表搜索

在项目中,一些没分页的列表的搜索功能由前端来实现,搜索一般分为精确搜索和模糊搜索。搜索也要叫过滤,一般用filter来实现。

const a = [ 1,2,3,4,5 ];
const result = a.filter(item => { return item ===3 })

如果是精确搜索不会用ES6中的find吗?性能优化懂么,find方法中找到符合条件的项,不会继续遍历数组
改进

const a = [ 1,2,3,4,5 ];
const result = a.find(item =>{return item ===3})

关于扁平化数组

一个部门JSON数据中,属性名是部门id,属性值是个部门成员id数组集合,现在要把有部门的成员id都提取到一个数组集合中。

const deps ={
'采购部':[1,2,3],
'人事部':[5,8,12],
'行政部':[5,14,79],
'运输部':[3,64,105],
}
Let member=[];
// 循环嵌套去扁平化
for (let item in deps){
const value =deps[item];
if(Array.isArray(value)){
member =[...member,...value ]}}
member =[ ...new Set(member) ]

改进: ES6的flat方法,无论是二维,三维,四维都能扁平化,方便快捷

const deps ={
'采购部':[1,2,3],
'人事部':[5,8,12],
'行政部':[5,14,79],
'运输部':[3,64,105],
}
Let member = Object.values(deps).flat(Infinity);

其中使用Infinity作为flat的参数,使得无需知道被扁平化的数组的维度。
补充
flat方法不支持IE浏览器。

七 关于获取对象属性值

const name = obj && obj.name

改进

const name = obj ?.name

八 关于添加对象属性

给对象添加属性时,若属性名是动态变化的,怎么处理

let obj ={};
let index = 1;
let key =`topic${index}`;
'obj[key]= `话题内容'

改进:ES6中对象属性名可以用表达式

let obj ={};
let index = 1;
obj [ `topic${index}` ] = ' 话题内容';

九 关于输入框非空的判断

在处理输入框相关业务时,往往会判断输入框未输入值的场景。

if( value !== null  && value !== undefined && value !==''){
操作....
}

改进:ES6中的空值合并运算符

if( (value? ' ') !==' ' ){
操作...
}

十 关于异步函数

异步函数很常见,经常是用 Promise 来实现。但是容易形成回调地狱

constfn1 =()=>{
return new Promise((resolve,reject) =>{ 
setTimeout(()=>{
resolve(1);
},300);
});
}
const fn2=()=>{
return new Promise((resolve,reject) =>{
setTimeout(
()=>{resolve(2);
},600);
});
}
const fn =()=>{
fn1().then(
res1 =>{console.log(res1);//1
fn2().then(res2 =>{
console.log(res2)
})
})
}

改进

const res1= await fn1();
const res2=await fn2();
console.log(res2) // 2

**
补充
但是要做并发请求时,还是要用到Promise.all()。**

const fn =() =>{
console.log(res); //[1,2]
})
}

**
如果并发请求时,只要其中一个异步函数处理完成,就返回结果,要用到Promise.race()**

这篇关于这些ES6用法你都会吗?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

解读GC日志中的各项指标用法

《解读GC日志中的各项指标用法》:本文主要介绍GC日志中的各项指标用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、基础 GC 日志格式(以 G1 为例)1. Minor GC 日志2. Full GC 日志二、关键指标解析1. GC 类型与触发原因2. 堆

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1

JavaSE正则表达式用法总结大全

《JavaSE正则表达式用法总结大全》正则表达式就是由一些特定的字符组成,代表的是一个规则,:本文主要介绍JavaSE正则表达式用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录常用的正则表达式匹配符正则表China编程达式常用的类Pattern类Matcher类PatternSynta

MySQL之InnoDB存储引擎中的索引用法及说明

《MySQL之InnoDB存储引擎中的索引用法及说明》:本文主要介绍MySQL之InnoDB存储引擎中的索引用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1、背景2、准备3、正篇【1】存储用户记录的数据页【2】存储目录项记录的数据页【3】聚簇索引【4】二

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的