ES6学习总结二

标签: Es6 分类: Javascript 创建时间:2020-07-08 09:40:37 更新时间:2025-01-17 10:39:22

1.async/awiat

这个其实就是把多个异步操作当成同步操作,但并不是真的同步。比如同时写两行await,只有等第一行异步执行完了,才去执行第二行,就好像我们在一个ajax的succss函数中,编写另外一个ajax请求一样。浏览器运行到第一个await,会暂停执行下面的语句,知道第一个语句执行完成之后,才进行下一步操作。

参考文章:
1.async 函数的含义和用法 (这里讲了async用法以及注意点和如何使用try/cathe块捕获异常)
2.async/await,了解一下?
3.JavaScript:async/await的基础用法
4.嘿,不要给 async 函数写那么多 try/catch 了
5.async function (MDN上的解释)

2.函数的默认参数

假如我们创建一个函数,并且给一个对象参数,但是对象参数使用默认值的,比如我们常用的一些函数库axios等,使用的时候,其中的data参数可以传,如果不传,则是默认的{}空对象。

1
2
3
axios({
data:{}
})

使用传统的方式就是

1
2
3
function axios(option){
var data=option.data||{};
}

使用新的es6语法可以这样做,可以不传值,也可以传其他的值,不传的时候,就使用默认值。

1
2
3
4
5
6
function axios({a = 0,b=1,c=2} = {a:0,b:1,c:2} ){
console.log(a,b,c);
}
axios(); // 输出 0 1 2
axios({a:5}); // 输出 5 1 2
axios({b:6}); // 输出 0 6 2
小额赞助
本人提供免费与付费咨询服务,感谢您的支持!赞助请发邮件通知,方便公布您的善意!
**光 3.01 元
Sun 3.00 元
bibichuan 3.00 元
微信公众号
广告位
诚心邀请广大金主爸爸洽谈合作
每日一省
isNaN 和 Number.isNaN 函数的区别?

1.函数 isNaN 接收参数后,会尝试将这个参数转换为数值,任何不能被转换为数值的的值都会返回 true,因此非数字值传入也会返回 true ,会影响 NaN 的判断。

2.函数 Number.isNaN 会首先判断传入参数是否为数字,如果是数字再继续判断是否为 NaN ,不会进行数据类型的转换,这种方法对于 NaN 的判断更为准确。

每日二省
为什么0.1+0.2 ! == 0.3,如何让其相等?

一个直接的解决方法就是设置一个误差范围,通常称为“机器精度”。对JavaScript来说,这个值通常为2-52,在ES6中,提供了Number.EPSILON属性,而它的值就是2-52,只要判断0.1+0.2-0.3是否小于Number.EPSILON,如果小于,就可以判断为0.1+0.2 ===0.3。

每日三省
== 操作符的强制类型转换规则?

1.首先会判断两者类型是否**相同,**相同的话就比较两者的大小。

2.类型不相同的话,就会进行类型转换。

3.会先判断是否在对比 null 和 undefined,是的话就会返回 true。

4.判断两者类型是否为 string 和 number,是的话就会将字符串转换为 number。

5.判断其中一方是否为 boolean,是的话就会把 boolean 转为 number 再进行判断。

6.判断其中一方是否为 object 且另一方为 string、number 或者 symbol,是的话就会把 object 转为原始类型再进行判断。

每日英语
Happiness is time precipitation, smile is the lonely sad.
幸福是年华的沉淀,微笑是寂寞的悲伤。