盘点:9款流行Web框架及其优缺点

对于Web开发人员来说,找到一些合适的工具,能让工作轻松许多。这其中,Web框架更是提升工作效率的"利器"。但因为可选的Web框架非常多,如何选择也是一件令人头疼的事情。

本文列出了9款目前比较流行的Web框架,并对优缺点进行分析,希望能对大家有所帮助。(内容主要编译自Ken Mazaika的The 9 Most In-Demand Web Frameworks And What You Need To Know About Them)

首先,什么是Web框架?

当Web浏览器使用HTTP和在其他地方运行的服务器(计算机)通讯时,这些服务器会收到一些通知:

所选的URL

如何输入网址(通过表单提交或只是在浏览器栏中输入网址)

服务器要干很多事情,比如:

读取数据库里的数据和添加数据

找到正确的结果(用户是否被允许查看试图访问的页面?是否要发送到不同的URL?等等)

构建用户将看到的网页

如果要提供更复杂的功能,就需要执行更多的步骤。作为开发人员,则需要对想要的功能列出一系列解决方案。Web框架就是其中可选的解决方案之一。

进入正题:

1、Ruby on Rails


编程语言:Ruby

简介:

Ruby on Rails是一个已经被许多公司采用的Web框架,是Ruby编程语言中Web框架的鼻祖,获得了大量开发者的采用。DHH(Rails的创始人)曾用它15分钟左右创建一个博客。

Rails的一大特点是约定优于配置(convention over configuration)。这意味着,它比较模式化、标准化和"约定化",开发者通常做的是相同的事情,可以让代码写到最少。

Rails还使用了MVC(Model-View-Controller),让架构更有组织性,更周密。

优点:

Rails具有强大的命令行界面,通过几个简单的命令就能在新的应用上启动和运行。

Rails已经存在很长时间了,并且广泛被使用,网络上有很多关于它的教程。

Rails简单易用,即便是复杂的问题,也能相对快速解决。

缺点:

Rails自动挂钩了很多东西。启动器里就包含很多文件,并且有相当多的配置代码是自动编写的,有些人可能会对此担心。

整体来看,鉴于其灵活性及便捷性,Rails是一个非常理想的Web框架,值得初学者优先学习。

2、Sinatra


编程语言:Ruby

简介:

上面的5行代码就是做一个最低限度配置的空Web应用所需要的全部代码,如果拿它和Ruby on Rails进行比较,会发现它需要的代码更少(而且只有一个文件,而不是几十个)。

然而,Sinatra的简单性是一把双刃剑。它用的是和Ruby on Rails相反的方法,需要开发者手动配置所有的东西。


优点:

Sinatra是轻量级框架的领头羊。

Sinatra高度可配置,注重开发的自由度。

缺点:

由于不侧重"惯例",没有相同的文件夹结构,所以会比较难去理解现有的Sinatra应用。

Sinatra不常用于实际生产项目当中。

手动配置很多东西往往需要更多的时间,效率会受影响。

3、ExpressJS


编程语言:JavaScript

简介:

ExpressJS是一个JavaScript Web框架,基于 Node.js。看起来有没有熟悉,它的代码非常类似Sinatra的代码,也有和Sinatra相似的简单性。在一个准 Express应用中只有两个代码文件:

package.json,这是NPM自动生成的文件。

app.js,这里包含着应用程序的完整代码。

优点:

高灵活性。

可以只使用一种编程语言。

轻量。

缺点:

更多选项=更多选择。选择意味着需要研究不同的选项,找出将它们应用到自己的项目当中的方法,这往往需要更多时间。

4、SailsJS


编程语言:Javascript

简介:

SailsJS可以看成是JavaScript版的Rails,有一个命令行工具去生成一个完整的默认应用程序,自带许多合理的默认配置和数值。

同样,Sails也有MVC架构,启动一个完整的应用也会有数十个默认的文件。

优点:

有许多默认已配置好的方法完成构建Web应用所涉及的大部分工作。

命令行程序使得构建新应用和功能更为轻松。

缺点:

尽管是一个看起来很强大的框架,人气也不低,但是并没有多少公司采用。

5、MEAN堆栈


编程语言:JavaScript

简介:

MEAN是ExpressJS的扩展,堆栈了如MongoDB、AngularJS和WebPack等技术。MEAN 用JavaScript一种语言来驱动整个应用。

MongoDB是一个在概念上与其他大多数据库有较大区别的数据库,它允许JSON数据在其中自由随意,这意味着数据库条目是灵活的,但同时也导致无效的记录成了一个非常容易遇到的问题。它不是通过SQL与数据库交互,而是使用其独有的JavaScript。

优点:

与SailsJS一样,MEAN堆栈包含构建复杂Web应用所需的所有组件。

缺点:

页面加载要两个阶段,而且第一阶段看起来有点搞笑。发生这种情况是因为视图不是在服务器端呈现,而只在浏览器中呈现。这意味着用户最初看到的是不完整的页面,页面的完整内容要过一会才能加载。

MEAN堆栈包含许多技术,如MongoDB,在其他框架中构建Web应用时通常不使用这些技术。

补充几句个人观点:

这个包含MongoDB的框架对我来说毫无意义,几乎所有其他Web框架都使用标准数据库SQL。在我看来,MEAN堆栈可能只在那些MongoDB真正"发光发热"的场景中有价值,但Mongo又是一个在高负载的时候才需要的东西,比如广告网络和API负载高的时候。

不可否认MEAN在某些情况下是有意义的,但对于典型的Web应用,我不太建议使用。因为MEAN在应用的每一个部分只使用JavaScript编程语言,这听起来会很容易掌握,但是像MongoDB和WebPack这样的东西使得MEAN实际上比那些解决问题的"标准"技术更困难。

6、Django


编程语言:Python

简介:

Django是一个运行在Python上的MVC Web框架。它也有一些打开即用的配置,它与Ruby on Rails框架有许多相似之处,也有不少区别。这个Web框架改变了控制器和视图的职责,但毫无疑问它是一个优秀的Web框架。

优点:

轻量、少配置。

提供完整的开发堆栈,同时仍然遵循Python的"清晰"语言的设计理念,允许在快速开发和长期维护之间实现平衡。

注意:

Python是一种类似于Ruby的语言,但它们的使用者会有不同的领域倾向,通常使用Python的开发人员往往是在数据科学、统计或分析领域工作。

7、Tornado


编程语言:Python

简介:

Tornado是一个没有怎么宣传的Python Web框架,它快速、高效,并允许开发人员访问python的大数据库。

优点:

在需要短时间内发生许多请求的情况下是优秀的。

缺点:

结构的缺乏导致应用相互不同。

对于初学者来说,拥有太多的自由可能会导致乱码。在其他的框架中有过经验的开发人员更愿意以深思熟虑的方式去构建应用。

8、Play


编程语言:Java或Scala

简介:

Play同样是一个轻量级的、无状态的Web框架,学到了rails的优点,使用构建在Akka之上的完全异步模型,提供可预测的和最小的资源消耗(CPU,内存,线程)。

优点:

在Java虚拟机上运行,Play是最高效的编程环境之一。

缺点:

大多数Web应用都是用所谓的"脚本语言"构建的,允许快速更改页面的视觉效果。Java增加了一个称为"编译"的步骤,需要在应用的更改之间进行。

9、Laravel


编程语言:PHP

简介:

Laravel是一个用PHP编写的框架。10年前,PHP是几乎所有Web应用构建的标准编程语言,不过如今,受Ruby、JavaScript和Python影响,PHP失去了很大的市场份额。

尽管如此,Laravel仍是一个非常成熟的框架,允许使用PHP构建漂亮的代码。

优点:

Laravel是一个很完美的MVC框架,借鉴了Ruby on Rails框架中使用的许多架构决策。

缺点:

使用PHP的开发人员和产品在减少(原文是这么写的^_^)

最后再说点

看完上面列出的这些不同的框架,很容易发现它们有互相在寻找灵感,许多功能、特性其实还蛮相似的。所以,说哪个好哪个不好,并没有什么意义,找到合适自己的才是关键。上面的框架可以简单分为两种类型:

一、简约框架

ExpressJS、Tornado和Sinatra都是简约框架,他们提供启动需要的最低配置。

这些框架需要开发人员手动添加每个单独的组件,给予足够的自由度去完成项目。此外,通过强制自己配置应用的各方各面,可以掌控更多主动权,并在每种情况下都使用理想的工具。

当然,也有一些缺点。会经常发现自己处于需要分析不同选项并做出很多选择的情况下。

二、Omakase框架

Rails、SailsJS、MEAN.io、Laravel和Play都是Omakase框架,它们建议开发者以某种"正确"的方式编写代码,并且给出社区标准。

这些框架提供开发所需要的一切,打开即可编程。如果想使用其他的东西,它们还允许选择停用。构建这些框架的开发人员已经为后来者做出了一些关键决策,因此可以遵循他们建议使用的模式。

这对初学者来说有很大的优势,初学者往往在学习Web框架的时候,你还需要学习数据库、HTTP请求、设置应用在Internet上运行等等知识。由于有一个被广泛接受的社区标准,学习一个像Rails这样的Web框架可以:

了解社区如何同意以正确的方式做某事。

有时间思考其他编程概念,学习其他知识。

一旦学习了某个框架社区的建议,将有经验来更好地评估其他框架。

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

此站点使用Akismet来减少垃圾评论。了解我们如何处理您的评论数据