WEB前端: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代码的工具,例如babel和traceur等。有很多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 js, remutable)、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,大家有兴趣可以自己去找找看。

原文转自:娱乐世界www.jxlazzw.com,娱乐世界平台www.shimanke.cn,转载请注明出处

时间: 2024-10-13 12:33:14

WEB前端:2015年值得关注的几个Web技术的相关文章

4个Web前端经典实用值得学习收藏的地图实现模板~

1.  无JS中国地图变色版 源码下载/  在线演示 2.  jQuery鼠标悬停中国地图网络销售网点提示信息 源码下载 /  在线演示 3. jquery开发的地图热点特效 jquery实现的,会在当鼠标光标移动到接近(或通过)视口(viewport)的顶部的时候触发. 源码下载 /   在线演示 4. 使用raphael.js绘制中国地图 能在支持 FireFox.Chrome.Safari.傲游.搜狗.360浏览器. 源码下载/   在线演示 4个Web前端经典实用值得学习收藏的地图实现模

百度web前端--2015一面

背景故事接上篇:http://segmentfault.com/a/1190000002738362hr 当时约的是今天或明天一面.我解释有下午考试,她说那今天晚上到明天.没想到上午百度的一位学长就打过来电话,说中午1点面试,,好吧,那就面吧,让暴风雨来得更猛烈些吧.(我的考试还没复习好呢) 学长先问了一下学校,然后聊了一下专业的课程,主要是问学了哪些计算机相关的课程.随后就切入主题,问什么时候开始接触web前端的.吧啦吧啦,,说了一通. 内容我简单回顾总结了一下面试官问的一些知识点: - HT

他曾经学完Web前端,给大家留下宝贵的学习web前端经验

前几天接触了一个叫小易的大专生,学机电一体化,我们都知道,现在大学都是在混日子,打游戏度日,大专更是如此,一个人很容易被环境影响,他的寝室也都是打了三年游戏过来的同学,他也是其中一个.毕业后,做了三个月的销售工作,像其他人一样,为了养活自己,只能找一个工作维持生活.用他的原话说:有一天他突然就意识到,似乎很多人的人生都是这样浪费掉的,一直做着自己不喜欢,杂七杂八的工作,不断的浪费着自己的时间,然后人到中年,一辈子就这个样子了.然后他想不能这样下去,必须要学一个东西,一直做下去,然后他租了一个小房

爱创课堂----Web前端开发的工资如何?都要学习哪些技术?

今天来和大家讲讲Web前端开发需要学习什么?前端开发又需要用到哪些开发工具?然后分享一些前端开发的免费课程给大家,然后也简单的和大家介绍下前端开发的前景和薪水工资情况,下面就简单和大家介绍一下. 1. Web前端的职能 Web前端工程师其实在不同的公司,有不同的职能,但是称呼都是类似的. 做网站设计.网页界面开发 做网页界面开发 做网页界面开发.前台数据绑定和前台逻辑的处理 设计.开发.数据 2. Web前端的核心技术 Web前端开发需要掌握的技术: 学习html,这个是最简单的,也是最基础的.

web前端开发怎么样学习?看这份web前端学习路线

前端开发是创建Web页面或app等前端界面呈现给用户的过程.前端开发通过HTML,CSS及JavaScript以及衍生出来的各种技术.框架.解决方案,来实现互联网产品的用户界面交互.它从网页制作演变而来,名称上有很明显的时代特征.在互联网的演化进程中,网页制作是Web1.0时代的产物,早期网站主要内容都是静态,以图片和文字为主,用户使用网站的行为也以浏览为主.随着互联网技术的发展和HTML5.CSS3的应用,现代网页更加美观,交互效果显著,功能更加强大. 随着时代的发展,现在从事IT方向的人有很

怎样学习Web前端?如何从基础到深入学习Web前端?

Web前端一直被认为是"上手快"."薪资高"的行业,随着需求的进步和用户需求的提高,Web前端开发人员需求旺盛,吸引了大批的人涌入这个行业.不过如何从基础到深入学习Web前端呢?就这个问题给大家简单分享一下方法. 很多人认为Web前端简单,可以自学,但往往在学习的过程中或求职时碰壁,究其原因还在于自学存在的两大缺陷.首先是自学容易钻进死胡同,没有一个好的学习路线和好的老师引导,你在遇到较难的知识点时就会碰壁,或长时间纠结在这一知识点,又或者是直接略过这个知识点,这都

2015年值得关注的几场IOT会议

1. 新加坡 4月8-9日  "IOT Asia 2015" http://www.internetofthingsasia.com/ 物联网亚洲会议2014开始新办,是针对这一新兴产业的需要,对超过1600家企业.政府机构和解决方案提供商,提供一个独特的平台,学习和利用物联网解决方案,以达到优化业务,降低成本,提高生产力和改善生活. In 2015, the second annual IoT Asia event will continue to raise the profile

百度web前端--2015二面

背景 故事再接上文:http://segmentfault.com/a/1190000002738459 昨天中午一面结束,感觉答得一般吧,很多知识点如Linux.PHP都没答上来.不知道能不能过. 不过我深深感觉到了自己知识点的一些不足,于是上午的电视概论课一边听一边看书,手机还开的标准模式.那可是班主任的课呀.. 很意外,上午居然有面试官打来电话约二面!百度的效率还是蛮高的呀.于是又约到了中午1点,一天课呀,没办法. 内容 首先你自我一下吧.好的,我--.吧啦吧啦,开始了.我提到了课程中的一

值得关注的大数据存储管理技术

目前电信.金融.零售等行业希望通过大数据的分析手段来帮助自己做出理性的决策.特别是电信和金融行业表现尤为突出,市场数据没有办法与用户消费数据打通.而它们面临的第一个问题就是海量数据存储的问题.多数企业正在试图建设自己的数据中心,来满足大规模的数据量的产生,或选择大数据相关工具来应对,如大数据魔镜等.成都UI设计培训机构但是随着数据的进一步增多,很多数据的查询和分析性能急剧下降,有的数据中心甚至出现了无法响应的状况,为企业的业务带来了很大损失. 企业的CIO们有着这样的疑虑,怎样的数据管理策略能够