站长资源网络编程
ES2020让代码更优美的运算符 (?.) (??)
简介链判断运算符(.)非常好用、常用,搭配Null 判断运算符使用,效果更佳,完美!来,上代码:我们通常获取一个对象多层的属性值时,需要进行多次的判断。如不判断,一个为空则报错,导致后面无法继续下去。// errorconst firstName = message.body.user.first
链判断运算符("htmlcode">
// error
const firstName = message.body.user.firstName;
// ok
const firstName = (message
&& message.body
&& message.body.user
&& message.body.user.firstName) || 'default';
// error const firstName = message.body.user.firstName; // ok const firstName = (message && message.body && message.body.user && message.body.user.firstName) || 'default';
也可以用三元运算符"htmlcode">
const fooInput = myForm.querySelector('input[name=foo]') const fooValue = fooInput "htmlcode">const firstName = message"htmlcode">"#C0FFEE".match(/#([A-Z]+)/i)"htmlcode">a"htmlcode">delete a"htmlcode">(a"htmlcode">// 构造函数 new a"htmlcode">const headerText = response.settings.headerText || 'Hello, world!'; const animationDuration = response.settings.animationDuration || 300; const showSplashScreen = response.settings.showSplashScreen || true;上面的三行代码都通过||运算符指定默认值,属性的值如果为''或false或0,默认值也会生效。
为了避免这种情况,ES2020 引入了一个新的 Null 判断运算符"htmlcode">
const headerText = response.settings.headerText "htmlcode">const animationDuration = response.settings"htmlcode">function Component(props) { const enable = props"htmlcode">// 报错 lhs && middle "htmlcode">(lhs && middle) ?? rhs; lhs && (middle ?? rhs); (lhs ?? middle) && rhs; lhs ?? (middle && rhs); (lhs || middle) ?? rhs; lhs || (middle ?? rhs); (lhs ?? middle) || rhs; lhs ?? (middle || rhs);ES版本更新的福利
在几个月前的腾讯开发者大会上,有位热心市民向ES开发者请教了这个问题,刚好借这篇文章的话题,在这里分享给大家!
关于ES版本更新,为什么ES5到ES6是大幅度书籍式的更新,此后版本更新只新增稀少的几个新技术?
原因:“怕你们学不动!”
其实,前者的更新方式,要学那么多东西,那么厚的一本天书,会给人一种望而却步的感觉,还没进门就先跪了。
后者来说,只是几个新技术,可能半天一天的,就能完全掌握并大结局了,收获的成就感会更多更快!