2015年值得关注的几个WEB技术

HTTP2

HTTP2在今年中应该就能够定稿,这无疑是web界的一个大事。HTTP2从google的SPDY中借鉴了不少特性,重点改善了以前HTTP协议在当前的网络环境下的性能。简单地来说,HTTP2更快。为何呢,有几个主要改变:javascript

  • 首先是来自于同一个domain的HTTP请求能够共享同一个TCP链接了,这样能够很大程度上解决网络延时带来的性能问题。好比你有不少图片,如今也不用sprite化了,由于反正它们会用同一个链接的。HTTP2的出现让以前的不少web前端优化技术可能再也不须要了。
  • HTTP2再也不是纯文本的了,而是二进制的协议了,这样协议的解析也更简单,而传输也更快。缺点是debug的时候须要费点功夫了。

HTTP2还有其余一些特性,例如header压缩等,你们能够到这里集中学习一下。或者看看这个FAQhtml

Firefox已经开始支持HTTP2,很多浏览器包括chrome以前就支持SPDY,估计对HTTP2的支持也会迅速开始,而nginx目前已经支持SPDY,就看何时各大主流web服务器开始支持HTTP2了。前端

一个不太好的现状就是开发人员可能得面临HTTP2和HTTP 1.1的同时存在。若是享受HTTP2的好处,同时又能向后兼容HTTP1.1,多是从此开发人员必须长期面临的问题了。java

ECMAScript6

咱们如今用的javascript(注意,是javascript语言自己,不包含DOM等其余东西)背后的标准是ECMA-262,也叫ECMAScript 5。它的下一个版本ECMAScript 6(简称es6),已经基本上快定稿了。这个版本里加入了不少开发过程当中须要的一些功能,例如:python

  • 类定义语法,包括super,继承
  • lambda风格的函数定义,=> block level函数定义内的lexical scope的this,默认参数,rest参数等
  • destructuring, 相似于ruby里的 [a, b, c] = [1, 2, 3],同时也适用于map和set,以及函数参数
  • symbol
  • iterator迭代器和generator,以及新的for of循环语法
  • template string,今后能够像在ruby和shell里同样使用多行字符串
  • module语法,从语言层面上支持了模块
  • 另外还有一系列新东西例如promise,proxy,unicode支持等

目前chrome和firefox已经开始逐步支持es6。不过你不用等到全部浏览器都开始支持es6后才可使用它,由于目前已经有不少把es6代码编译成es5代码的工具,例如babeltraceur等。有不少js的库已经开始使用es6的各类功能了,其中包括angular 2.0。nginx

不少人应该在用coffeescript,es6的不少功能弥补了以前es5的缺陷,吸取了不少coffeescript的功能,也许之后咱们就能够不用coffeescript了,除非你不喜欢大括号小括号,而喜欢python的语法。不过若是coffeescript不进行升级,估计就享受不到未来es6带来的好处,也难以适应HTML5时代各类数值计算的需求。git

最后给你们一个比较不错的es6学习资源,这本书写得很细,如今仍是在线免费的。es6

Immutable js and React

React相信你们已经不陌生了,它是facebook开源的一个前端view框架,这里之因此提到它是由于它背后的理念所带动的一些技术。React自己虽然只是一个view框架,可是背后的virtual dom以及随之带来的性能优点是吸引人的地方,另外就是它采用的相似web component的封装概念。这里有一个比较js前端框架性能的试验,虽然不是很准确,可是能够做一个参考。github

React的virtual dom以及它管理前端控件数据的方法,和immutable数据结构(immuatble jsremutable)、functional programming是能够很容易结合起来使用的。clojurescript的om框架就是一个例子。想象一下全部的状态都是不可变的,而且统一数据存储(flux架构例如marty),每次数据的更新均可以很容易只传递diff(event source模式),整个数据在前端的流动都是单向的,不只变成模型变得简单,并且由于全部的历史数据都没有被实际修改过,因此undo和redo的实现也会变得很容易。web

React经过virtual dom实现了immediate模式的UI编程,低成本和快速的UI刷新也带了人们更多启发,而且React这种封装方式也变得不局限于dom view了。例如flipboard团队基于React的封装风格在canvas上封装了一层UI,能够实现精细的动画效果,保证web版和移动版的体验一致。facebook的React团队最近在React会议上也发布了一个能够用js和React API进行原生移动开发的框架

React也许只是另一个web view框架,可是我喜欢它给我带来的一些新想法,这些想法也许可让咱们在前端开发上更容易些。

Realtime web(实时web技术)

如今的web对实时性要求愈来愈高,这不光是因为如今的技术能够更好地支持实时性,也是因为用户体验的驱动。实时性不光是体如今聊天这种需求上;咱们在手机上的操做,web浏览器上最好可以实时体现出来,即使咱们不刷新页面,页面也应该可以实时获得更新。

前端因为HTML5的出现对于实时需求有了更好的技术支持,例如新的WebSocket、WebRTC,long polling以及server push技术。然后端则早就出现了async IO编程技术,可以同时支持大量长链接。可是这些技术的进步历来没有中止过,这里给你们随便介绍几个。

pushpin是fanout最近开源的一个高性能实时web后端技术,不一样于其它的技术,它是一个proxy,自己不提供API编程框架,而是和已有的web API结合起来,让它们变成支持大量长链接的API。从设计概念上,它把维护大量长链接这个功能和实际的API业务功能分离开来,让前一个功能经过proxy的形式来实现,所以对实际API的框架和语言没有要求,若是要支持更多长链接,也能够经过横向扩展这个proxy来实现,而不必定要改动后端API。

sockjs,是一个websocket的模拟,在支持websocket的浏览器上就会使用原生websocket,而在老的浏览器上则提供替代技术。可是它不止是一个前端js库,它也同时提供了后端的编程框架,目前支持的语言和框架挺多了。

websocketd是一个有意思的东西,它能够把任何符合接口的程序编程一个websocket后端,你甚至能够用shell来写API。

不少的web框架都支持异步编程模式,于是能够支持大量并发长链接。也有相似于meteor这种提供总体解决方案的,还有不少近期的firebase,你们有兴趣能够本身去找找看。


转自 2015年值得关注的几个WEB技术

相关文章
相关标签/搜索