|  |      1dV9zZM1wROuBT16X      2020-04-16 14:32:01 +08:00  1 这语法在其他语言也不是很罕见的,比如 swift | 
|  |      2asAnotherJack      2020-04-16 14:33:19 +08:00  1 kotlin 也有这种语法 | 
|      3mercury233      2020-04-16 14:33:51 +08:00 可空类型,不算冷门 | 
|  |      4murmur      2020-04-16 14:34:14 +08:00  1 ?。这语法太超前了,虽然各种 objectPath 类组件早就在用,可以一次访问很深层的节点,不用一层层判空 | 
|  |      5cmdOptionKana      2020-04-16 14:34:26 +08:00 现在主流语言是天下语法一大抄,越来越趋同了。 | 
|  |      6skies457      2020-04-16 14:35:11 +08:00  4 | 
|  |      7devwolf OP 感谢楼上的各位解疑,原来是其他语言已经存在的语法,get 了 | 
|  |      8Lin0936      2020-04-16 14:36:43 +08:00 最近在 kotlin 里写这个都写吐了. 之前 swift 的项目里也用到很多. | 
|  |      9yaphets666      2020-04-16 14:38:13 +08:00 我写了一年多 js 也 不知道这个...我是不是太菜了 | 
|  |      10crs0910      2020-04-16 14:38:48 +08:00  1 你还可以使用 ?? 来代替 ||,避免需要判断值是不是 0 这种情况 关键词:Nullish Coalescing | 
|      11vivipure      2020-04-16 14:39:15 +08:00  1 dart 也有。这是 ES2020 的新语法,挺好用的,不用在写什么 a && a.b 之类的了。 | 
|  |      12aaronlam      2020-04-16 14:39:45 +08:00  1 刚开始看到时,我也是很震惊的。 但是实话实说,这个语法的确很实用,不对吗? | 
|  |      13U7Q5tLAex2FI0o0g      2020-04-16 14:40:51 +08:00 写 swift 的时候经常这么写。现在的语言很多都开始互通有无了,都会相互借鉴对方的一些东西 | 
|  |      14itechify PRO  1 kotlin 里面有,thymeleaf 模板写对象判断非空也是用这里的语法 | 
|      15islxyqwe      2020-04-16 14:49:02 +08:00 新版本 ts 提前支持的 Optional Chaining 等 ES2020 的新语法拉 | 
|      16liuy1994g      2020-04-16 14:55:16 +08:00 via Android es 里还在提案吧 | 
|  |      17noobma      2020-04-16 14:56:09 +08:00 关注 ts 的话应该不会觉得这个写法冷门😂 | 
|      18Justin13      2020-04-16 14:59:15 +08:00 via Android 建议关注 ECMA262 repo | 
|  |      19luob      2020-04-16 15:03:21 +08:00 写 js 的不都是天天跟着最新语法标准走吗,这种最近大半年都在谈的语法就算没用过,总不至于没听过吧…… 还是说现在前端已经足够成熟,大家都不学新内容了? | 
|  |      20crz      2020-04-16 15:03:21 +08:00 主要是新,冷门应该不至于,毕竟很实用 | 
|      21g00001      2020-04-16 15:05:01 +08:00 我觉得还是 aardio 中的直接下标更简洁好用, if( a[[b]] ){ } 不管 a 是什么都不会抛异常,不是对象返回 null,可以节省好多代码。 比 swift,kotlin,js 什么的出现早多了,国产小语言也是有亮点的。 | 
|  |      22baozijun      2020-04-16 15:09:40 +08:00  1 Safe calls are useful in chains. For example, if Bob, an Employee, may be assigned to a Department (or not), that in turn may have another Employee as a department head, then to obtain the name of Bob's department head (if any), we write the following: bob?.department?.head?.name Such a chain returns null if any of the properties in it is null. | 
|      23sarlanori      2020-04-16 15:15:10 +08:00  1 C#也有这个语法了 | 
|  |      25xianxiaobo      2020-04-16 15:26:15 +08:00 有意思,学到了 | 
|      27jadehare      2020-04-16 15:31:43 +08:00 ts 有插件会自动不上。。虽然我自己写还是 if 判断一下 | 
|  |      28zmqking      2020-04-16 15:35:08 +08:00 c# 里面也有! | 
|      299ki      2020-04-16 15:36:57 +08:00 要多想 | 
|      30Lax      2020-04-16 15:37:53 +08:00 为了减少对父元素的空置判定,尤其是很多个级别。 a.b.c.d 这种,if(a) { if(a.b) { if(a.b.c) { a.b.c.d }}}},不想一级一级判断的时候就很方便了。 | 
|      31goodboy95      2020-04-16 15:38:05 +08:00 握草,刚刚试了一下,除了?.运算符之外,??运算符也被支持了! var a = {sa: 3, sb: 4}; var b = null; console.log(a?.sa ?? 5); // 3 console.log(b?.sa ?? 5); // 5 | 
|  |      32yolee      2020-04-16 15:51:37 +08:00 c# 也是用这个判断是否为空的 | 
|  |      33lower      2020-04-16 15:53:45 +08:00 语法糖 | 
|  |      34Veneris      2020-04-16 15:55:28 +08:00 dart 也有 | 
|  |      35no1xsyzy      2020-04-16 15:55:38 +08:00 https://caniuse.com/#feat=mdn-javascript_operators_optional_chaining 太超前了,FF 和 CR 各只过了两个版本,过 babel 可行( angular 可以用大概就是 babel 的原因?) 早前 coffee 就看到了 | 
|  |      36lithbitren      2020-04-16 15:55:49 +08:00 ?? 和 || 有啥区别啊 | 
|      37liukangxu      2020-04-16 16:02:05 +08:00 看来 C#还是有人用的。。。 | 
|      38apeople      2020-04-16 16:05:42 +08:00 angular 也只是能在模板中使用吧,要想在 ts 中使用还是得配置 babel 插件。 | 
|  |      39DivineRapierH      2020-04-16 16:07:40 +08:00 via iPhone  1 @Lax #30 这种我一直是用 lodash 的 get 一把梭 | 
|  |      40Removable      2020-04-16 16:07:57 +08:00 C#里我经常这么用,比判断==null 方便多了 | 
|  |      42devwolf OP @lithbitren  https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Operators/Nullish_coalescing_operator 摘录: 由于 || 是一个布尔逻辑运算符,左侧的操作数会被强制转换成布尔值用于求值。任何假值( 0, '',NaN,null,undefined )都不会被返回。这导致如果你使用 0,''或 NaN 作为有效值,就会出现不可预料的后果. 空值合并操作符??可以避免这种陷阱,其只在第一个操作数为 null 或 undefined 时(而不是其它假值)返回第二个操作数。 感谢#10 提供了拓展和线索 | 
|  |      43lithbitren      2020-04-16 16:13:49 +08:00 @devwolf 蟹蟹,MDN 常看常新啊 | 
|  |      44Ritter      2020-04-16 16:35:34 +08:00 666 | 
|      45gromit1337      2020-04-16 16:37:56 +08:00 @vivipure #11 对对 | 
|  |      46iugo      2020-04-16 16:44:37 +08:00 VS Code + TypeScript 会给我强推这种写法. | 
|  |      47iugo      2020-04-16 16:46:38 +08:00  1 | 
|  |      48iugo      2020-04-16 16:48:23 +08:00 推一下前两天我们关于 nullish coalescing operator post: https://zsqk.github.io/news/2020-04-08-nullish-coalescing-operator.html | 
|      49klgd      2020-04-16 16:54:40 +08:00 上次遇见了一次,搜了半天才知道是干什么的  还有`!!` | 
|  |      50ZZITE      2020-04-16 17:07:47 +08:00 Optional Chaining 去年写的 ts 项目就在用了,在 react 项目中很舒服。 | 
|      51lneoi      2020-04-16 17:10:46 +08:00 这是新语法啦,很实用的 | 
|  |      52AlynxZhou      2020-04-16 17:11:51 +08:00  1 看起来楼主没写过 coffeescript 啊,coffeescript 里面有这个问号运算符 | 
|      53jtwor      2020-04-16 17:13:36 +08:00 c# 空运算 | 
|      54Rwing      2020-04-16 17:14:32 +08:00 很棒的语法啊,c#首创的吧? | 
|  |      55luzemin      2020-04-16 17:20:43 +08:00 C#的语法糖 | 
|  |      56est      2020-04-16 17:23:27 +08:00  1 ruby 里可以直接 inline 外挂一个 exception  更方便。不管是 . 挂了还是别的什么挂了都能正常执行。 | 
|      57xuchdeid      2020-04-16 17:28:35 +08:00 TypeScript 啊 。。。 | 
|      58IllBeBack      2020-04-16 17:30:15 +08:00 | 
|      59ershierdu      2020-04-16 17:42:25 +08:00 学 swift 的时候感觉这个有点绕,项目做完后不再写 swift 就忘了 | 
|      60wszgrcy      2020-04-16 17:55:16 +08:00 via Android ts 3.7 的语法吧 | 
|      61mrleft      2020-04-16 18:03:06 +08:00  1 | 
|      62g00001      2020-04-16 18:03:18 +08:00 c# 6.0 ( 2015 年) 才有 Null 条件运算符,应当是比较晚了。 国产小语言 aardio 在十多年前就有了类似的语法,不仅仅是对象,任何对象都可以 if( a[[b]] ){ } ,真正的有鸭子的声音就可以当鸭子用,说到偷懒这个事,我们还是行的。 只能 null 对象,还是会有麻烦,如果是其他类型呢,还是要写判断,偷懒还是不够彻底这不行的。 | 
|      63jin7      2020-04-16 18:10:10 +08:00 php 早就有了 | 
|  |      64ansenJ      2020-04-16 18:26:25 +08:00 ES7+后的新语法 我知道有 但是不知道在哪个版本里 | 
|      65optional      2020-04-16 18:41:46 +08:00 via iPhone js 生态就要经常上来看看 tc39,ts 可以经常看看 roadmap | 
|  |      66ccyu220      2020-04-16 18:45:08 +08:00 除了 ts , 暂时还不敢用。 | 
|      67g00001      2020-04-16 18:45:17 +08:00  1 PHP 就更晚了,PHP 7 才有 $d = $a->$b->$c ?? 'DEFAULT' 的写法,不是很简洁。 | 
|  |      68TarotVoyager      2020-04-16 18:48:04 +08:00 via iPhone C#基本操作,ts 也有 | 
|  |      69xrr2016      2020-04-16 18:50:37 +08:00 Dart 里面经常用...还有 ?? 语法 😝 | 
|  |      70Chingim      2020-04-16 18:53:42 +08:00 via Android 多关注 tc39 | 
|  |      71en20      2020-04-16 19:00:49 +08:00 via iPhone 最近写 flutter,看别人的库经常这种语法 | 
|  |      72y4ZIZrCL74b9MYl6      2020-04-16 19:13:54 +08:00 很有用 学习了 | 
|      73mingtianjiayou      2020-04-16 19:53:45 +08:00 新语法哈哈 | 
|  |      74nekochyan      2020-04-16 19:59:11 +08:00 没记错的话是 es7 新语法吧,一般情况下不敢用,怕不支持😄 | 
|  |      75shenyu1996      2020-04-16 20:11:43 +08:00 最近新开项目 下意识在使用 ?.  ... 这些语法   说真的 能少掉好多头发 少些好多代码 | 
|  |      77shenyu1996      2020-04-16 20:15:32 +08:00 ``` { name: 'aaa', ...(true && {age: 10}) } ``` 比如像这种神奇的写法 真的能让自己少掉好几根头发 | 
|  |      78Felldeadbird      2020-04-16 20:36:29 +08:00 我印象中 PHP7 也有这种语法。但是我还是喜欢用传统的:?判断为主。 太新的语法我怕其他人调式出错。就蒙蔽了。 | 
|  |      79cnit      2020-04-16 20:53:49 +08:00 thymeleaf 里面经常会用到 | 
|  |      80cbais7890      2020-04-16 20:57:45 +08:00  1 可选链啊, 如果用过 Swift 肯定会觉得很熟悉 实际上 a?.b 就等于 a && a.b 的意思, 防止对不存在的变量读取属性而产生异常 在处理某些前后端交互的不稳定数据时相当舒服 | 
|      81LukeChien      2020-04-16 20:58:27 +08:00 via Android 现在很常见了,以前在模板引擎语法里很常见 | 
|  |      82yxcoder      2020-04-16 21:06:01 +08:00  1 因为 js 里面访问 undefined 或者 null 的成员会报错,所以如果调用很深,譬如这种,a.b.c.d.e.f,为了防止报错,要这么写 a?a.b?a.b.c?a.b.c.d?a.b.c.d.e?a.b.c.d.e.f:null:null:null:null:null 巨难看 所以出了个语法糖 a?.b?.c?.d?.e?.f | 
|      83Pursue9      2020-04-16 21:15:24 +08:00 C# 还有  ??  ??= a?.b 等同于 if(a == null) return null 还有 a??0 等同于 if(a == null) return 0 a??=0 等同于 if(a == null){ a = 0; return a;} | 
|      84SilentDepth      2020-04-16 21:23:47 +08:00 @Pursue9 #83 Logical Assignment Operators,ES 这边已经 Stage 3,如无意外明年就纳入规范了 | 
|  |      85IGJacklove      2020-04-16 21:28:25 +08:00 via Android 还好吧,flutter 早就有这个语法了,kotlin 也有类似的语法,简单来说就是简化判空操作的,js 听说要新加这个语法,当时跑了是还不能用的 | 
|      86SilentDepth      2020-04-16 21:29:56 +08:00 Optional Chaining 不仅有 foo.bar?.qux ,还有 foo.bar?.( ) 呢 :-) | 
|  |      87LeiNaD      2020-04-16 21:35:42 +08:00 可选链 | 
|      88bilberry      2020-04-16 21:42:40 +08:00 ES2020 里面的 | 
|      89bilberry      2020-04-16 21:42:53 +08:00 | 
|      90weyou      2020-04-16 23:10:49 +08:00 via Android Python PEP505,不过这语法确实有点 magic,不符合 Python 的一贯风格,难怪还没被采纳 | 
|      91somebody      2020-04-16 23:21:57 +08:00 很多语言都有,这个叫 Safe navigation operator, Wikipedia 有 18 种语言的例子 https://en.wikipedia.org/wiki/Safe_navigation_operator | 
|      92jinliming2      2020-04-16 23:23:24 +08:00 @yxcoder 您这个就算没有 ?. 语法,也可以不用 ?: 啊…… 用 ?: 是丑,但是直接 a && a.b && a.b.c && a.b.c.d && a.b.c.d.e && a.b.c.d.e.f || null 也稍微好看一些啊…… (虽然还是 ?. 更香 | 
|  |      93HytonightYX      2020-04-16 23:37:44 +08:00 我还写过 webpack 的实现,不过只是用了正则替换来判断,不是很完美。 TC39 有关于可选链的解释。 | 
|  |      94hst001      2020-04-17 00:11:34 +08:00 很好用的语法糖,各大语言应该引入 | 
|  |      95errolli      2020-04-17 00:12:25 +08:00 C#里面就有。。。 后来换到用 Java 的公司就没这个待遇了 | 
|      96FutherAll      2020-04-17 00:18:05 +08:00 via iPhone optional 更适合用来解包判空之类的。 如果用来判断布尔的话是有歧义的,比如:if (a?.b == 0)或者 if(a?.b == false),到底是 a 为空还是 a 不为空 b 为 false 或者 b 为空 | 
|  |      97param      2020-04-17 00:50:35 +08:00 via Android 原来 JS 也有了 | 
|  |      98Yumwey      2020-04-17 00:51:57 +08:00 via Android 可选链,香的很。震惊啥   TS 强推 | 
|  |      99guolaopi      2020-04-17 09:30:57 +08:00 我写 C#,这玩意儿都写了好几年了,基本就是日常。。。。。 学新语言的时候觉得没有 x?.x 还有 x??y 这种写法很别扭。。。。 | 
|      100ugu      2020-04-17 10:13:17 +08:00 angular 里面经常写 |