取值
普通场景
const obj = {
a:1,
b:2,
c:3,
d:4,
e:5,
}
const {a,b,c,d,e} = obj
const f = a + d
console.log(f)
其他场景:解构默认值重命名
服务端返回的数据对象中的属性名不是我想要的,如上取值依旧需要重新创建各遍历赋值
语法: 元值:重命名值
const {a:a1} = obj;
console.log(a1);// 1
补充
注意:解构的对象不能为 undefined null 否则会报错,故要给被解构的对象一个默认值
const {a,b,c,d,e} = obj || {};
合并数据
//数组
const a =[1,2,3]
const b =[1,5,6]
const c = a.concat(b)
//对象
const obj1 ={
a:1
}
const obj2 = {
b:1
}
const obj = Object.assign({},obj1,obj2)
console.log(obj)
ES6
const a = [1,2,3];
const b = [1,5,6];
const c = [...new Set([...a,...b])];//[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}的考试成绩不及格`;
}
在${}中可以放入任意的JavaScript表达式,可以进行运算,以及引用对象属性。
const name = '小明';
const score = 59;
const result = `${name}${score > 60?'的考试成绩及格':'的考试成绩不及格'}`;
if中判断条件
if(
type == 1 ||
type == 2 ||
type == 3 ||
type == 4 ||
){
//...
}
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
}
)
console.log(result)
优化:精确搜索可以使用 ES6中的 find, find方法找到符合条件的项就会停止遍历
const a = [1,2,3,4,5]
const result = a.find(item=>{
return item === 3
})
console.log(result)
扁平化数组
场景:一个部门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)]
//[1, 2, 3, 5, 8,12, 14, 79, 64, 105]
优化:
- 获取对象的全部属性 Object.values
- 数组的扁平化处理 ES6 flat
注:其中 Infinity 做为 flat 的参数,使得无需知道被扁平化的数组的维度 ,flat 不支持IE浏览器
const deps = {
'采购部':[1,2,3],
'人事部':[5,8,12],
'行政部':[5,14,79],
'运输部':[3,64,105],
}
let member = Object.values(deps).flat(Infinity)
console.log(member)
获取对象属性值
const name = obj && obj.name
const name = obj?.name
添加对象属性
当给对象添加属性时,如果属性名是动态变化的,该怎么处理
let obj = {}
let index = 1
let key = `topic${index}`
obj[key] = '话题内容'
console.log(obj)
let obj = {}
let index = 1
obj[`topic${index}`] = '话题内容'
输入框非空的判断
if(value !== null && value !== undefined && value !== ''){
//...
}
空值合并运算符
if(value??'' !== ''){
//...
}
异步函数
const fn1 = () =>{
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 fn = async () =>{
const res1 = await fn1();
const res2 = await fn2();
console.log(res1);// 1
console.log(res2);// 2
}
补充:做并发请求时,还是需要用到 Promise.all()
const fn = () =>{
Promise.all([fn1(),fn2()]).then(res =>{
console.log(res);// [1,2]
})
}