版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、JavaScript的新技术特性介绍技术创新,变革未来2/192Slide199823/192SlideIE 434/192Slide个写了20+年JS的男4Slide前ES3时代 19951999ES3时代 20002010Harmony时代 20082016后ES6时代 20162020TS/JS态新时代 20205/19256/192Slide36075team67/192Slide360级前端架构师360技术委员会Web前端TC委员78/192Slide2019年7起TC39代表89/192SlideECMA9SlideECMA-334 C# Language SpecicationE
2、CMA-335 Common Language Infrastructure (CLI)ECMA-367 Eiel programming Language ECMA-376 Oce Open XML (ISO/IEC 29500)ECMA-388 Open XML Paper SpecicationECMA-408 Dart language specicationECMA-410 NFC-SEC Entity Authentication and Key Agreement using Asymmetric CryptographyECMA-411 NFC-SEC Entity Authe
3、ntication and Key Agreement using Symmetric Cryptography10/1921011/192SlideChina IWNCOMM电捷通2014-62018-6?11SlideECMA-262 ECMAScript Language Specication ECMA-357 ECMAScript for XML (E4X) (废弃)ECMA-402 ECMAScript Internationalization API ECMA-404 JSON12/1921213/192SlideJavaScriptECMAScript1314/192Slide
4、JavaScriptECMAScript1415/192SlideTC3915SlideGoogle AppleMozilla Microsoft Facebook16/19216SlideIBMIntelPaypal Stripe17/19217Slide360AirbnbBloomberg GoDaddy Salesforce18/19218SlideEvernote IgaliaMeteor npmOpenJS Foundation19/1921920/192Slide建渠道2021/192Slide聊聊JS的个新特性2122/192Slide已完成的提案2223/192Slide每年6
5、-8个提案2324/192SlideES2020前5个24SlideStotype.matchAll import()BigInt Promise.allSettled globalThis25/1922526/192SlideStage 326SlideNullish Coalescing Optional ChainingStotype.replaceAll ?27/19228/192SlideNullish Coalescing Operators2829/192Slide?2930/192Slidea ? b3031/192Slidea != undefined& a
6、 != null? a : b3132/192Slidea != null ? a : b32Slidea ? a : b a | b33/1923334/192Slidetruthy/falsy34Slidestring: | vboolean: false | vnubmer: 0 | v number: NaN | v Array: | vObject: (35/192valueOf() return0 ) | v3536/192Slidenullish36Slidea != null ? a : b37/19237Slidea.b.c() ? va.b.c.d ? v38/19238S
7、lidea.b.c() != null ? a.b.c() : va.b.c.d != null ? a.b.c.d : v39/1923940/192SlideSide eects40SlideOAOO DRY41/19241Slideeval Once And Only Once Dont Repeat Yourself42/1924243/192Slidea != null ? a : ba != undefined & a != null ? a : b4344/192Slidedocument.all4445/192SlideTypeScript4546/192Slidea ? ba
8、 必须是 nullish46SlideT|undefinedT|nullT | null | undefined47/19247Slidea ? b | c a | b ? c a ca c?b&b ?48/1924849/192SlideSyntaxError4950/192Slide必须加括号5051/192Slide未决问题优先级51Slide等于 ?: GNU C、Groovy(?:)于 | C#、PHP、Dart、Coee等 于 | Perl(/)于 =:Swift、Kotlin52/1925253/192Slidev ? complex_expression5354/192Slid
9、ecomplex_expression ? v54Slidea = b ? c (a = b) ? ca = (b ? c)55/19255Slidea * b ? c (a * b) ? ca * (b ? c)56/1925657/192SlideOperator precedence5758/192SlideTypeScript5859/192Slidea ? ba 必须是 nullish5960/192Slide(a OP b) ? c定都是错误代码6061/192Slidea OP b ? c定都是错误代码6162/192Slidea OP(b ? c)6263/192Slidea
10、? b OP c理解上存在歧义63Slide(a *OP* b) ? (c *OP* da OP b ? c OP d怎样动x?)a OP (b ? c OP d)a OP (b ? c) OP d64/1926465/192Slide于较运算符:Swift、Kotlin6566/192Slide于*(所有元运算符)6667/192Slidea OP b ? c6768/192Slidea OP b ? c OP d6869/192Slidea ? b OP c6970/192Slide较保守的团队可以定制lint规则7071/192Slide相对简单的lint规则只禁 a ? b OP ca
11、 ? b 或 者 a ? (b OP c)71Slide现在可能需要lint规则a OP b ? ca ? b OP ca OP b ? c OPd72/19272Slide优先级7373/19274/192Slide#157475/192SlideOptional Chaining7576/192Slidea?.b7677/192Slidea != undened & a != null ? a.b : undened7778/192Slidea != null ? a.b : undened7879/192SlideNullish-aware Operators7980/192Slidea
12、 != null ? a.b : undened8081/192Slidea & a.b8182/192Slidetruthy/falsynullish8283/192Slidea & a.b & a.b.c8384/192SlideSide eects84SlideOAOO DRY85/1928586/192Slidedocument.all8687/192SlideTypeScript8788/192Slidea?.ba 必须是 nullish88Slidea?.b.ca?.b?.c89/1928990/192SlideShort-circuiting9091/192Slidea?.+x9
13、192/192Slidea = null ? undened : a+x9293/192Slidea?.b.c(+x).da = null ? undened : a.b.c(+x).d9394/192SlideLong short-circuiting94Slidea?.b.c (a?.b).c95/19295Slidea = null ? undefined : a.b.c (a = null ? undefined : a.b).c96/19296Slidea?.b.c.d a?.b?.c?.d97/1929798/192SlideTypeScript静态类型检查 可以严格地确定每个部分
14、 应该a.b还是a?.b9899/192Slidea?.b.c?.d99Slidea?.ba!.b100/192100101/192SlideNon-null assertion101102/192Slidea!102SlideconstH=constK=console口.codePointAt(0).toString(16)口.codePointAt(2).toString(16).log(H, K)103/192103SlideconstH=constKconsole口.codePointAt(0)!.toString(16)口.codePointAt(2)!.toString(16).l
15、og(H, K)104/192104SlideconstH=constKconsole口.codePointAt(0)?.toString(16)口.codePointAt(2)?.toString(16).log(H, K)105/192105Slideconst lang = localStorage.getItem(lang) ? en-US const labels = i18n.load(lang)const user = JSON.parse(localStorage.getItem(user) document.querySelector(bdi#user-name)!.text
16、Content =user?.name ? labels?.non-login-user-name ? anonymous106/192106Slidea?.b a?.key107/192107108/192Slidea . b - a key a ?. b - a ? key 108Slidea?ba?b:c109/192109110/192Slidea?b?c:d110111/192Slide其他语?111112/192SlideC#:数组是 .112113/192SlideCoeeScript:没有 ?: 三元113114/192SlideSwift:空格区分!114115/192Sli
17、detry a?.b?c115Slidea?.b a?.prop a?.(.args)116/192116117/192Slidea != null ? a(.args) : undened117Slidea?(.)a?.(.)118118/192119/192SlideC#:a?.invoke(.)119Slidea.b?.(.)a.b?.invoke(.)120/192120121/192SlideStage 2121Slidea?.ba?key a?(.args)122/192122Slidea?.ba?key a?(.args) a ? b123/192123Slidea?.b a?k
18、ey a?(.args) a ? ba?&b a?&key a?&(.args) a ? ba?b a?key a?(.args) a ? ba?.b a?key a?(.args) a ? ba.b akey a(.args) a b a?.b a?.key a?.(.args) a ? b124/192124125/192Slide主要use casea?.b 80%+a ? b125126/192Slidedelete a?.b126127/192Slidea = null? true: delete a.b127128/192Slide不持的128Slidenew?.target im
19、port?.(foo)new a?.()new a?.b()super?.()super?.foo a?.string a?.bstringa?.b = c129/192129130/192Slidea?.b = c130Slide/ syntax error document.querySelector(#test)?.innerHTML += .131/192131Slide/ okdocument.querySelector(#test)?.insertAdjacentHTML(beforeend, .)132/192132133/192Slide#18133134/192SlideQA
20、134135/192SlideStotype.replaceAll135Slideabaa.replace(a, A)/ Abaaabaa.replace(/a/, A)/ Abaa abaa.replace(/a/g, A) / AbAAabaa.replaceAll(a, A)/ AbAAabaa.replaceAll(/a/, A)/ Ab? abaa.replaceAll(/a/g, A) / AbAA136/192136SlideAbAA (auto g) Abaa (consistency?)throw TypeErrordo not allow RegExp at all (ch
21、ange API name to substitue)137/192137138/192SlideStotype.matchAll138Slideabaa.match(a)abaa.match(/a/)/ a, index: 0, input: abaa/ a, index: 0, input: abaaabaa.match(/a/g) / a, a, a139/192139Slideabaa.matchAll(a) / (a, index: 0, input: abaa)abaa.matchAll(/a/) / ?abaa.matchAll(/a/g) / (a, index: 0, a,
22、index: 2, a, index: 3)140/192140141/192SlideStage 4!141Slideabaa.replaceAll(/a/, A) / TypeError! abaa.matchAll(/a/)/ TypeError!142/192142143/192SlideglobalThis143Slidewindow selfglobal144/192144145/192SlideWhy globalThis145146/192Slideglobalhttps:/git/tc39/proposal-global146Slideif (typeof global = object) / code for node.js else / code for browser147/192147Slideself globalObjectglobe Global148/192148149/192SlideglobalThis149150/192Slide安慰下150151/192Slide只是
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 储蓄存款和商业银行课件
- 《中海国际社区Y》课件
- 网络布线施工规范-洞察分析
- 司法考试行业数字化转型研究-洞察分析
- 数字营销在医药行业的应用-洞察分析
- 网络调度实时性优化-洞察分析
- 糖尿病视网膜病变早期玻璃体改变研究-洞察分析
- 云计算平台安全性对比-第1篇-洞察分析
- 医疗干部评职称的述职报告范文(9篇)
- 《市政道路施工技术》课件
- 心灵的幻象 课件-2023-2024学年高中美术湘美版(2019)美术鉴赏
- 藏式餐饮创业计划书
- 建筑安装工程有限公司关于加大市场开拓力度的激励办法
- 题库(大气科学基础(一)-题库)
- 智能制造设备与工厂自动化项目验收方案
- 箱变调试方案
- 部编版小学语文五年级下册习作5《形形色色的人》教学反思共三篇
- 冷库冷藏库施工组织及售后服务投标方案
- 统编版语文一年级上册 j q x y 和 ü 的专项练习(无答案)
- 城市轨道交通工程质量安全控制要点
- 护士n2晋升n3层级申请范文
评论
0/150
提交评论