阅读更多

8顶
0踩

Web前端

转载新闻 2015年值得关注的几个Web技术

2015-03-03 09:57 by 副主编 mengyidan1988 评论(0) 有7883人浏览
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,大家有兴趣可以自己去找找看。

来自:简书
来自: 简书
8
0
评论 共 0 条 请登录后发表评论

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

  • 2015年邮件营销人员最值得关注的10个焦点

    2015年上半年,几乎大部分欧美国家的大中小型电子商务企业以及快消品公司,他们无不关注并探讨着邮件营销领域相似的焦点话题。究竟有哪些话题是邮件营销发达国家的从业者们所重视的呢?Webpower中国区营销专家带你涨...

  • Go 1.16中值得关注的几个变化

    辛丑牛年初七开工大吉的日子(2021.2.18),Go核心开发团队为中国Gopher们献上了大礼 -Go 1.16版本正式发布了[1]下载到Go 1.16在各个平台的安装包:2020年双...

  • 2019-2020年值得关注的9个AR发展趋势

    2019-2020年值得关注的9个AR发展趋势

  • 2017年Web前端技术综述

    Web前端应用发展的历史大概经历了三个阶段:第一个阶段使用的是简单的静态页面,第二个阶段使用得是ASP、JSP、PHP等动态脚本语言,第三个阶段是Web2.0阶段,其核心技术是AJAX,同时伴随着SPA的兴起。SPA vs. MPA从...

  • 2015年技术回顾

    所幸的是,2015年在服务器应用技术这里,企业应用模式老祖又给业界抛出了一个新概念: 微服务 。我查了N多资料,也没找到踏实落地的技术细节。看来,微服务,是2016年快速发展的技术领域。云/分布式、Docker/集装箱...

  • 2015年十大黑客测试工具你认识几个?

    来自:FreeBuf.COM关注黑客与极客(微信号:freebuf) 原文地址:concise-courses,FB小编FireFrank编译 链接:http://www.freebuf.com/tools/91462.html 如果你真的喜欢安全,了解下面这些工

  • 【阿朱原创】2015年技术回顾

    所幸的是,2015年在服务器应用技术这里,企业应用模式老祖又给业界抛出了一个新概念: 微服务 。我查了N多资料,也没找到踏实落地的技术细节。看来,微服务,是2016年快速发展的技术领域。云/分布式、Docker/集装箱...

  • Web 开发在 2015 年及未来的发展趋势

    Web 开发在 2015 年及未来的发展趋势 2014/10/07 | 分类: WEB前端, 开发 | 3 条评论 | 标签: GO, NODE.JS, RESTFUL, SPA, WEB开发 分享到: 74 本文由 伯乐在线 - Jaward华仔 翻译自 shijuvar。未经许可,禁止...

  • 2016 上海 Qcon 值得关注的技术

    标注: pholcus是用go语言实现的一个爬虫框架, github地址 https://github.com/henrylee2cn/pholcus 标题 内容 URL 作者 Vue 2.0: 渐进式前端解决方案 Vue.

  • web前端技术不断迭代,我们如何突破?

    进入 2019 年,大前端技术生态似乎进入到了一个相对稳定的环境,React 在 2013 年发布至今已经 6 年时间了,Vue 1.0 在 2015 年发布,至今也有 4 年时间了。 整个业界在前端框架不断迭代中,也寻找到了许多突破方向...

  • 2021年值得关注的8种SEO趋势

    2021年值得关注的8种SEO趋势1.新的用户体验指标将影响排名如何优化2.将在所有网站上强制进行移动优先索引如何优化3.人工智能将统治所有搜索如何优化4.实体将与反向链接同等使用如何优化5.饮食因素可能起更大作用如何...

  • Web前端技术 Web学习资料 Web学习路线 Web入门宝典

    学习路线 第一章 核心 1.Node Node.js 就是运行在服务端的 ...Node.js是一个事件驱动I/O服务端JavaScript环境,基于Google的V8引擎。相当与JDK。 Github: https://github.com/nodejs/node 官网教程: h...

  • 2016年前端技术观察

    前端技术,从最初的刀耕火种到现在的百花齐放、繁花迷眼,可以说达到了一个前所未有的鼎盛时期。当身边的同事张口闭口都是所谓H5的时候,作为一名前端开发者的我心中越来越多的却是迷惑和不解。 我并不完全赞同这篇...

  • 2018年Java开发值得学习的10大技术

    作为一个开发人员,我们最大的挑战就是保持自己了解新的技术。...除了这些离我们较远的,说几个离我们最近的:JDK 9、 Spring 5、 Spring Security 5、 Spring Boot 2、ServiceMesh等。这一年对于一个Jav

  • Go Web 编程

    内容简介 本书全面介绍使用 Go 语言开发 Web 应用所需的全部基本概念,并详细讲解如何运用现代设计原则使用 Go 语言构建 Web 应用。...本书以一个网络论坛为例,讲解如何使用请求处理器、多路复用器、模板引擎、存储...

  • 面试阿里被怼了,面试官说我没关注这几个公号

    不少同学担忧的情况——“晋升无望、收入见顶、生活开支飙升、财务危机如影随形”,小编精心挑选了几个优质原创技术号,推荐给大家化解成长的烦恼。他们都是我平时关注的优秀号主,分...

  • 十年WEB技术发展历程

    我抱着试一试的心态给了网吧老板两块钱想申请个号玩玩,然后接下来的一个小时我一直在,注,册,账,号。 彼时网吧用的512k的带宽,注册的时候,填了一堆信息,提交,页面跳转,嘣,"您填写的信息有误,请重填"。...

  • 【自然语言处理(NLP)】机器翻译之数据处理(数据收集、数据清洗、数据分词、数据标注、数据划分)

    【自然语言处理(NLP)】机器翻译之数据处理(数据收集、数据清洗、数据分词、数据标注、数据划分)

  • fence-agents-rhevm-4.2.1-41.el7-9.6.x64-86.rpm.tar.gz

    1、文件内容:fence-agents-rhevm-4.2.1-41.el7_9.6.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/fence-agents-rhevm-4.2.1-41.el7_9.6.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、安装指导:私信博主,全程指导安装

Global site tag (gtag.js) - Google Analytics