一份来自InfoQ的Web开发趋势报告

2018年04月02日 20:53infoQ 作者:David Iffland, David 标签:Node.js  Vue.js  WEB 

Web开发领域几乎每过几分钟就会出现一个JavaScript开发框架,它们通常都很短命,这种现象非常有意思。要在这些框架中做出选择真的不容易,Vue.js,Angular,React...

要点

  • CSS和ECMAScript是Web的基石,它们将继续发展演化。我们也看到其他的一些东西,比如WebAssembly,它为开发者带来了新的想象空间。
  • 报告中增加了GraphQL和WebVR这两个主题。
  • 我们认为Vue.js越来越受欢迎,我们把Vue和Angular加入到React的行列当中,也就是进入了早期大众阶段。
  • 我们在报告中移除了Ember.js、backbone.js和knockout.js,因为我们认为它们已经到了寿终正寝的时候。尽管我们还在观望jQuery,但它可能也即将走进历史。
  • Web开发者所使用的主流文本编辑器有VS Code、Atom、Sublime和WebStorm,以及vim风格的编辑器。

InfoQ每年都会更新主题图表,以体现技术趋势的变化。我们的编辑团队从各种渠道获得技术的实践状态、新出现的想法,当然也会把QCon现场的参与情况考虑在内。

对于位于图表右边的技术,你或许可以在InfoQ网站上找到很多与之相关的内容,因为在这些技术刚出现的时候,我们对它们进行了报道。当个人、团队和组织想要采用这些技术时,由创新者和早期采用者提供的指南对他们就有所裨益。

位于图表左边的是刚出现的技术,通常是创新者和早期采用者在使用这些技术,我们致力于报道这些内容,把这些新想法带给我们的读者,这样他们就知道是否该学习这些新技术或者关注它们的发展情况。

在过去几个月,我们已经发布了有关文化、云计算和DevOps的报告。这个月,我们要发布的是Web开发报告。

Web开发领域几乎每过几分钟就会出现一个JavaScript开发框架,它们通常都很短命,这种现象非常有意思。要在这些框架中做出选择真的不容易。

WebAssembly是过去几个月出现的一个主要的新趋势,它是一个Web标准,定义了一种二进制格式和类似汇编的文本格式,以便在Web页面上执行代码。现在所有的浏览器都支持WebAssembly,我们认为它将会成为一个非常重要的标准。

CSS方面出现了CSS网格、CSS Houdini和可变字体,这些也非常有意思。这一领域也是我们会一直关注的领域。

这次我们把GraphQL也加了进来,它是Facebook于2012年开发的一种数据查询语言,打着“浏览器即平台”的口号,被当作是REST的替代方案。我们认为它也是一门非常有趣的技术,也值得我们关注。

ECMAScript方面也有很多动作,我们把ECMAScript 2018放在了创新者当中。

最后,我们也把WebVR加入到了创新者当中。WebVR是一套试验性的JavaScript API,目的是在Web浏览器上为虚拟现实设备提供支持,比如HTC Vive、Oculus Rift、Google Cardboard或OSVR。我们到现在还没有发现一款“杀手级”的VR应用,这项技术或许仍然处于利基阶段,不过从浏览器和JavaScript的角度看,它还是值得我们关注的。

我们把Vue.js和Angular移到了早期大众中。React仍然是老大哥,不过Vue在中国得到广泛的采用,正在变得越来越流行,所以我们认为它已经进入了早期大众阶段。我们把Angular分为Angular2/Angular4+和AngularJS。有人建议把Angular去掉,但我们认为到现在为止还没有足够的理由这么做。

我们仍然看到jQuery的存在,尽管我们认为它已经是昨日黄花。我们把它归入了后期大众,并继续观望。

我们之前也跟踪过HTML5,不过这次把它拿掉了。在新生代Web发展的阶段,它确实起到了保护伞的作用,不过我们认为这个时期已经过去了。

我们把Ember、Backbone和knockout移除掉了。如果它们有新的动态,我们会继续报道。但在目前来看,人们对它们似乎已经没有什么兴趣了。Stack Overflow也得出了类似的结论:

我们也关注了文本编辑器和IDE。我们看到,开发者使用最多的编辑器是VS Code、Atom、Sublime Text和WebStorm,以及vim风格的编辑器。这个与2017年发布的JavaScript状态报告及其他问卷调查中所提到的清单是一样的(顺序可能不一样)。

查看英文原文:Web Development InfoQ Trends Report,作者:David Iffland David Iffland

0条评论