JSConf China 2017 Day One — JavaScript Change The World

今天有幸参加了 JSConf China 2017 ,作为大会第一天,我来谈谈个人对大会的一些感想。至于大会讲的更加详细的内容可以直接翻到本文末尾,我和另外一个位前端小伙伴一起写的非常详细的笔记,版权在掘金,感兴趣的可以点链接去看看。

第一场 Programming the Universal Future with next.js

第一场是来自 ZEIT 的大神,讲的是 next.js。

现场演示了 React 是如何利用 next.js 进行服务器端渲染的。

next.js 支持 static projects、package.json(node 项目)、Dockerfile 项目配置一键部署。

开发中常见的需求:自定义 URL,服务端渲染、实时日志,这些也都只需要一个 next 命令就可以搞定!

现场演示了经过 next.js 改造之后的服务器端渲染的性能,页面首屏直接秒开,再也没有了 loading 半天的情况了。用户体验极佳。除了这个以后还演示了懒加载 React 组件。React 组件可以按需加载,再也不用一开始加载所有组件了,这样提高了很多性能。演示中还展示了 next.js 的热加载的功能,hot-reload ,极大的提高了开发效率。

第二场 理解现代 Web 开发

这个演讲提到了太多的话题了。而且演讲过程中语速非常快,keynote 一页一页的。涉及的点实在是广,据说前端没有五到十年经验是无法领悟到其中的精髓的。

这一讲讲师放出了PPT,很值得大家去学习,链接在这里《理解现代 Web 开发》

关于讲师的 GitHub 上还有一个《现代 Web 开发者的魔法书 Spellbook of Modern Web Dev》 同样非常推荐阅读。

1. 如何看待开发的变化

未来的开发形式走向(移动化 ----> AI 时代 ----> XXX时代的前夜) 这些问题都比较值得我们深思。

2. JavaScript Fatigue

根源在于:

  1. 多样性
    开发者基数大,每年增加100%,明年超过 Java,任何时候都有 50% 社区成员今年才开始写 JS。
  2. 需求多
  3. 成本低
    JS 是抽象层最高的语言之一,使用的API是抽象层对高的 API 。

JavaScript Fatigue 的解决办法是:普及维护低成本,填补缺失的中间层。

3. Awesome List

现在批评了 awesome list 这种 repo,列表膨胀,无效过时的curation太多。缺少和结构。然后安利了 spellbook,spellbook 就是对 awesome list 的缺点进行的改良,还提供最细粒度的类别。

4. CSS 的未来

CSS最大的趋势,从面向文档转变成面向组件。

5. Web开源生态

  1. Web开源生态 = npm 生态
  2. 五大流派
  3. universal JS

第三场 后 ES6 时代的 JavaScript 语言

这一场是由百姓网的 贺老 Hax 带来的分享。前半段主要谈 ES6 的新特性是如何被各大浏览器厂商完美支持的。中间遇到了不少困难。还有各个提案是如何一步步的从 S0 到 S4 落地的。

中间主要谈 ES7 的新特性,这里谈到了 JS 的单线程的问题,这个问题我听的比较认真,毕竟客户端开发的同学平时都是接触到多线程的概念。

JS 是单线程?

Worker 其实就是类似线程。Worker 的通信是消息传递的,message 事件传递的。一般多线程编程里面是共享内存。

RTC ,run to completion,JS 函数从头运行到底,一般都不会被打断的。JS 是使用 run to completion 语意的语言。在增加 Async/Await 打破了run to completion 语意,但是还是可控的,只在标识了 Async/Await 的地方可能会有变量的改变,其他没有标识的地方还都是 run to completion 可控的。SharedArrayBuffer 也同理。

node.js 没有 worker,不过node.js开发组已经考虑会加入相关的 API。

最后,贺老提到了更多的新特性,import() 动态加载、数组和对象的展开运算符、正则表达式的一些特性、global 变量、Class 特性扩展支持私有属性、上周新提出的提案 Pattern Match、WebAssembly等等。还有更多细小的点,看下图吧:

第四场 前端工程中的编译时优化

这一场就是尤大的演讲啦!尤大的演讲稿分享地址

前端 JavaScript 虽然是脚本语言,没有 buildtime,但是现在前端工程里面一样需要有编译的过程。在编译的时候可以进行分析和优化。V8 的实现中就有相关的编译工程,会把 JavaScript 的源码最终编译成机器码。

平时我们经常会用到 JS 的 modules ,但是模块化了以后,打包以后会难以压缩代码。为了解决这个问题,就诞生了 Rollup。

webpack 3.0 以后的版本通过 ModuleConcatenationPlugin 插件支持了 Treeshaking 的特性。

前端编译的优化方案

前端工程化发展到今天,慢慢的开始思考编译器能做哪些优化,原则是:

Do more at build time,Do less at runtime。

于是在 build time 的时候,大家想出了很多优化的点:

Svelte 是一个完全依赖于编译的框架。可以不依赖任何 runtime 的 lib 就可以编译 JS 代码。

Relay Modern 通过静态的预编译摆脱昂贵的 runtime query construction。

Prepack 的思路比较清奇,它会在编译器把能计算的东西都计算好,然后用计算好的结果直接替换源代码。比如一个函数返回值如果是固定的。那么 Prepack 在编译器就会直接把这个函数的返回值计算完,然后删除掉这个函数,只留下这个返回值。

Rakt 在应用层面进行编译时优化。

最后讲了 Vue 在 编译器的8点优化:

  1. Hoisting Static Trees
  2. Skipping Static Bindings
  3. Skipping Children Array Normalization
  4. SSR Optimizing Virtual DOM render functions into string concat
  5. SSR inferring async chunks
  6. SSR inlining Critical CSS
  7. IDEA compile away parts of vue that's not used in your app
  8. IDEA styletron-style atomic CSS generation at build time

我主要关注了 SSR 的3点优化:

第五场 学习 React Native 你需要知道的一切

React Native 对很多客户端开发的同学算比较熟悉了。

开始分析了一下 RN 为什么会这么流行:

  1. 热更新
  2. 使用现代 web 技术开发移动端
  3. 跨平台

RN 对应的缺点:

  1. Breaking changes 太多
  2. 文档不易理解,导致学习成本高
  3. Navigation:导航组件问题校对

这里重点谈了 Navigation 的问题,给了以下这些可选的方案:

最后谈到了 State 状态管理,分享者也谈到了 Redux 比较重,推荐了另外3个库:Mobx、Mobx State Tree、Dva。

所以 RN 的 状态管理可以用以下这些方式了:

  1. Built-in state
  2. Redux
  3. Mobx
  4. Mobx State Tree
  5. Dva

第六场 TypeScript, Angular 和移动端的跨平台开发

这一场是一个来自 Google 的工程讲 Angular。

开场就安利了一波 TypeScript。

然后接着讲 Angular。

Angular 笔者实在没有用过,这里不多介绍它了。

讲完 Angular 又讲了 Ionic Framework。

最后又讲了 Native Script。这个是 Angular 的跨平台原生框架,对手就是 Vue 的 Weex,React 的 React Native。

下面三种图分别是 Native Script 的介绍和跨平台原理。

目前用到最多的就是 React Native,Weex 用的人都不是很多(还在用 Weex 的可以在文章下面留言),笔者周围在用 Native Script 开发的,十个手指头都数的过来(用 Native Script 开发的可以在文章下面留言)。

鉴于 Native Script 使用度不是很高,这里也不多说了。

第七场 Ruff loT 应用开发

这一场讲的是如何用 JS 去开发硬件。软件工程师也可以用高级抽象语言 JavaScript 去开发物联网了。Ruff 把底层的硬件代码都封装起来了。
传统的硬件代码大概像下面这样:


GPIO.output(11, GPIO.HIGH)

这段代码大多数的软件工程师可能都看不是很懂。

General Purpose Input Output (通用输入/输出)简称为GPIO,或总线扩展器,人们利用工业标准I2C、SMBus或SPI接口简化了I/O口的扩展。当微控制器或芯片组没有足够的I/O端口,或当系统需要采用远端串行通信或控制时,GPIO产品能够提供额外的控制和监视功能。

第一个入参11,一般人也不知道这个是干嘛的。在硬件里面有00,01,10,11这几个值。

HIGH是高电平。在硬件编程里面会有高电平,低电平。

如果能把这些令软件工程师费解的硬件代码封装成上层软件可读性比较强的代码,就会对软件工程师非常的友好。

如果封装成下面这样:


led.turnon()

软件工程师一眼就知道这在干什么了,可读性非常强。这句话就是在打开一个 LED 灯。

Ruff 平台就做了这些事情,把复杂的硬件代码都封装了成简单易用的 JS API 了。

JavaScript 工程师可以用 jQuery 给孩子写玩具了!

最后如果想看更加详细的笔记,请看掘金这个链接,是我和另外一个小伙伴一起记录的。

感想

第一天讲了这么多主题,其实感受的到,当今的 JavaScript 语言能做的事情越来越多了,所以文章的标题取名为 JavaScript Change The World。

全场听下来,收获最多的可能就是尤大讲的吧。这次大会其他讲师有些分享可能平时开发中也不会用到,不过听听各家对前端技术发展的不同看法也是挺不错的。

前端虽然近几年发展突飞猛进,“魔爪”向前伸向了客户端,向后伸向的后端,向下伸向了硬件,看似无所不能。但是前端依旧还有很多可以改进的地方,比如 JS 的 Class,多线程。这些都可以像面向对象的语言学习。前端工程化也可以慢慢考虑编译期优化了,这块对于客户端开发语言,天生就是编译语言来说,Clang + LLVM 里面的黑魔法般的优化也许值得前端学习的点也挺多的。

GitHub Repo:Halfrost-Field

Follow: halfrost · GitHub

Source: https://halfrost.com/jsconf_china_2017/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,395评论 25 707
  • 已经进入小学的校园快三个月了,为了可以成为一名优秀的小学生,要充分利用课余时间,我制定了以下的学习计划 周五:...
    张轩赫阅读 173评论 0 4
  • 斜风 密雨 我在炉火上煮一壶茶 温暖自己 花开随意 绿透帘里 布谷声急 千秋惹多少人提笔 浓淡相宜
    黛眉居阅读 269评论 1 5
  • 旅行的意义是什么? 今天在黄河壶口瀑布,我望着人山人海,想到了这个问题。 我看见很多小孩子在玩土坑里的积水,或用手...
    清妍景河阅读 377评论 0 0
  • 扑克牌是我们几乎每个人都可能玩过的游戏。最基本的扑克玩法都是一边摸牌,一边理牌。假如我们拿到了这样一手牌,如图9-...
    丨ouo丨阅读 303评论 0 0