【转载】Web开发技术发展历史-版本2

原文在这里node

Web开发的发展史

导读:Arunr 把过去 15 年以来,Web开发从最初的纯 HTML 到 CGI、PHP\JSP\ASP、Ajax、Rails、NodeJS 这个过程简要地进行了介绍。web

在接下来的几个月时间里,我打算写一系列关于完整web开发的文章。这第一篇文章虽然有所粗略,但也可以充分归纳了在以前15年或者更久的时间里web应用程序如何进行演变。而且最后我会囊括下这段时间内所写的相关技术。mongodb

在过去的美好日子里,咱们使用的是简单的web页面(包括动态gif图片!)。做为精美设计的典范,苹果有着这样的一个网站:数据库

 

在那时,Web开发还比较简单,开发者常常会去操做web服务器(主要仍是他本身的机器),而且他会写一些HTML页面放到服务器指定的文件夹(/www)下。这些HTML页面,就在浏览器请求页面时使用。express

 

问题就出现了,你只能获取到静态内容。假若你想让访问者看到有多少其余访问者访问了这个网站呢(还记得那些统计流量的旋转图片吗?!),或者假若你想让访问者去填写这样一个表单,包含有姓名和邮件地址呢?于此就转向了CGI和Perl脚本,在web服务器端运行一段短小的代码,并能与文件系统或者数据库进行交互。浏览器

 

 

当时组织CGI/Perl这样的脚本代码太混乱了。CGI伸缩性不是太好(常常是为每一个请求分配一个新的进程),也不太安全(直接使用文件系统或者环境变量),同时也没提供一种结构化的方式去构造动态应用程序。几年来一直很困惑,直到大约2005年左右,出现了Java Server Pages(JSP),微软的ASP,以及PHP!我喜欢把当时的参考架构比做成IIS和ASP.NET,你能够用Visual Studio快速构建一个可伸缩而且安全的应用程序。安全

 

 

直到当时,web服务器多半会返回整个页面或者文档,但AJAX(2005)的出现,让事情变得颇有意思。AJAX容许客户端的JavaScript脚本为局部页面提供请求服务,而后能够在无需回到服务器状况下动态刷新部分页面,也就是更新浏览器中的document对象,一般称做DOM,或者文档对象模型。服务器

虽然从服务器端返回的仍然是HTML,但浏览器上的代码能把这HTML片断内嵌到当前页面中。也就是说web应用的响应能够更快,这时咱们真正用web应用取代了web页面。谷歌的GMail和谷歌地图都是当时AJAX的杀手级产品。随后用AJAX局部刷新就如雨后春笋般出现。架构

 

在随后的几年时间里,AJAX成为了焦点,但在服务器端仍然使用着旧有的技术。大概在2007年,37signals公司公开其成员–Ruby on Rails。那个基于Ruby on Rails 5分钟构建博客的演示彻底征服了全世界的开发者。一晚上之间,因此谈论的焦点都是关于Rails!Rails的不一样之处在于使用规定的方式去设计你的web应用程序,运用一种已经普遍在桌面应用开发,但未被搬到web应用上的开发模式。这种模式就叫作模式(数据)-视图(模板)-控制器(业务逻辑)。Rails强调,“这事就该这么作”,而且经过许多插件让构建web应用再一次更加健全。框架

 

 

在2007到2010年期间,涌现了3种开发潮流:

第一个是智能手机和移动应用潮流。一般状况下,许多应用程序同时有web和移动应用两种版本。尽管如此,服务端仍然返回的是HTML页面,而不是其它移动应用能够识别。所以,你须要返回的是结构化数据来取代HTML。

第二个开发潮流是jQuery。这是一个很是流行的JavaScript库,可以很容易构建动态、美妙的web应用,甚至是AJAX!

第三个潮流是Node.JS的发布。这是第一次能让你用JavaScript开发高性能的服务端程序,进而可能结束“客户端开发者”要知道HTML/JavaScript,“服务端开发者”要知道.NET/C#/Ruby这样的噩梦。

 

 

尽管这是一个不错的架构,但咱们能够重用一些在客户端的收获去简化那些曾经发生在像客户端意大利面似的jQuery代码。和Rails精神相似,咱们须要用一种规定的方式从服务端获取到数据,再对客户端的HTML页面进行包装。所以,在接下来的2年时间里,业界出现了许多用于简化客户端开发的框架,诸如Backbone,Ember,Derby和Meteor,固然也包括个人最爱,AngularJS。

 

 

所以,这就是咱们看到的今天,而我后面要讲到的参考架构是这样的,mongodb做为数据库服务器,node/express做为web应用服务器,客户端使用AngularJS,同时也使用Bootstrap样式风格。我发现这种架构容许我可以快速构建web服务以及基于AngularJS的客户端接口,甚至和其它的服务,如PhoneGap或者其它原生移动开发工具同样,进行移动应用的开发。

相关文章
相关标签/搜索