首页 > 其他分享 >这些ES6用法你都会吗?

这些ES6用法你都会吗?

时间:2024-09-08 11:52:44浏览次数:7  
标签:ES6 const name ... 用法 这些 let obj

一 关于取值

取值在程序中非常常见,比如从对象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,const,name,...,用法,这些,let,obj
From: https://blog.csdn.net/m0_73890048/article/details/142023675

相关文章

  • ES6中try-catch
    在ES6(ECMAScript2015)中,try-catch 语句的语法和使用方式与在之前的ECMAScript版本中是一样的。try-catch 语句用于处理代码中可能发生的错误,确保程序的健壮性和用户体验。基本语法try{//尝试执行的代码块//如果发生错误,则执行catch块中的代码}catch(er......
  • crypto插件的用法
    文章目录1.概念介绍2.方法与功能2.1基本用法2.2加密算法3.示例代码4.内容总结我们在上一章回中介绍了"FlutterCacheManager组件"相关的内容,本章回中将介绍一个加密工具包.闲话休提,让我们一起TalkFlutter吧。1.概念介绍加密主要是为了保护一些重要数据,我......
  • 2024最全前端面试系列(ES6)(ES6你不得不知道的新特性)
    functionfn(){return“HelloWorld”;}foo${fn()}bar//fooHelloWorldbarSymbolSymbol是ES6新增的基本类型。Symbol值通过Symbol函数生成。这就是说,对象的属性名现在可以有两种类型,一种是原来就有的字符串,另一种就是新增的Symbol类型。凡是属性名属于Sy......
  • python PaddleOCR库用法及知识点详解
    识别图片的设置https://blog.csdn.net/f2315895270/article/details/128147744?utm_medium=distribute.pc_relevant.none-task-blog-2~default~baidujs_baidulandingword~default-0-128147744-blog-89082526.pc_relevant_default&spm=1001.2101.3001.4242.1&utm_relevant_in......
  • 铺先生:为何会出现店铺转让?这些原因你了解过吗
    为何会出现店铺转让?任何一家转店的产生都是有原因的,作为经营者若是我们能够提前了解到,那么就有机会能够提前做好准备去避免,今天小编就来跟大家简单聊一聊会导致转店出现的几个原因吧。1. 选址不好相信如今的经营者都认识到了选址的重要性了吧,若是一开始的选址不好那么你的经营必然......
  • 一文了带您了解 ES6 Class 用法
    文章目录一、概述二、用法2.1基础用法2.2封装与继承2.3继承一、概述ES6中的class是基于JavaScript中的一个强大的属性,也就是原型属性prototype,由这个属性改良得来的一种语法糖。在ES6中,class(类)作为对象的模板被引入,可以通过class关键字定义类。class的本......
  • 提升编程效率:这些工具让您事半功倍
    精选编程工具,助力开发者高效编码在软件开发的世界里,优秀的工具可以极大地提升开发者的工作效率。选择合适的编程工具,不仅能够节省时间,还能提高代码质量,让开发者的生产力翻倍。本文将为您介绍几款备受推崇的编程工具,它们在提升工作效率方面表现出色。一、代码编辑器:VisualSt......
  • 抓包工具tcpdump用法说明
    tcpdump采用命令行方式对接口的数据包进行筛选抓取,其丰富特性表现在灵活的表达式上。不带任何选项的tcpdump,默认会抓取第一个网络接口,且只有将tcpdump进程终止才会停止抓包。例如:shell>tcpdump-nn-ieth0icmp下面是详细的tcpdump用法。1.1tcpdump选项它的命令格式......
  • 响应式单位rpx及搭配UI产品工具和@import导入css样式和scss变量与用法static目录以及p
    1.响应式单位rpx及搭配UI产品工具1.对于rpx的认知和用法以及对于px的区别我们可以去官网先了解一下我们的rpx用法和注意以及与px的区别。链接:页面样式与布局|uni-app官网(dcloud.net.cn)我平时使用的px是我们的屏幕像素的单位,我们在一个页面创建一个view组件,并且给其在......
  • JS-ES6
    这篇文章是关于ES6(ECMAScript2015)新特性的介绍和教学,作者通过具体的代码示例和解释,帮助读者理解和掌握这些新特性。下面是对文章中提到的ES6特性的总结和注释:ES6块级作用域let○在ES6之前,JavaScript只有全局作用域和函数作用域。let关键字的引入为JavaScript带来了块......