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

HTTP2

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

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

HTTP2还有其他一些特性,例如header压缩等,大家可以到这里集中学习一下。或者看看这个FAQ

Firefox已经开始支持HTTP2,不少浏览器包括chrome之前就支持SPDY,估计对HTTP2的支持也会迅速开始,而nginx目前已经支持SPDY,就看什么时候各大主流web服务器开始支持HTTP2了。

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

ECMAScript6

我们现在用的javascript(注意,是javascript语言本身,不包含DOM等其他东西)背后的标准是ECMA-262,也叫ECMAScript 5。它的下一个版本ECMAScript 6(简称es6),已经基本上快定稿了。这个版本里加入了很多开发过程中需要的一些功能,例如:

  • 类定义语法,包括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。

很多人应该在用coffeescript,es6的很多功能弥补了之前es5的缺陷,吸收了很多coffeescript的功能,也许以后我们就可以不用coffeescript了,除非你不喜欢大括号小括号,而喜欢python的语法。不过如果coffeescript不进行升级,估计就享受不到将来es6带来的好处,也难以适应HTML5时代各种数值计算的需求。

最后给大家一个比较不错的es6学习资源,这本书写得很细,现在还是在线免费的。

Immutable js and React

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

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

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,大家有兴趣可以自己去找找看。

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,398评论 25 707
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,016评论 4 62
  • 老大在现任老师那里补课俩次后,老师在学校对她格外的好,这时,补课班的老师也通知她去上课,孩子很纠结,问妈妈...
    崔槐春阅读 244评论 0 1
  • 最近新来的同事,当然也是熟人,另外一个同事的老婆。两个人家都算外地的吧,男方内蒙的,女方我们这里另外一个县城的。双...
    27ebdf2ac0e0阅读 659评论 0 0
  • 工作之余刷微博,娱乐圈炸窝了,中国娱乐圈资深媒体人第一狗仔卓伟,爆出消息称:白百合婚内出轨,并宣称已和丈夫陈羽凡离...
    老街茶馆阅读 214评论 0 1