1990 年蒂姆·伯纳斯·李(Tim Berners-Lee)在欧洲粒子物理实验室里开发出了世界上第一个网页浏览器,从此互联网时代来临,前端技术也随之不断发展。在长达 40 年的互联网时代,前端技术从简单的文本信息,发展到现在丰富多样的信息时代,到底经历了什么样的技术变革呢?我们解决呢什么问题呢?它为什么会这样变化?它的未来有是如何呢?这些都是值得我们去思考的问题,让我们重返历史,和了不起的科学家、工程师们一起来体验技术的变革。
在整个前端发展过程中,我们一直在解决这三个问题:工程化、性能、跨平台。
计算机起源
互联网的出现离不开计算机技术的出现,100多年前约瑟夫·亨利发明的继电器也许就是计算机的最早雏形,就在人类的启蒙时代人们用理性的思考改变这时代的变迁,摩尔斯在1839年将信息以电波的形式发送到远方时,已经奠定了现在通讯的基础。1854年布尔用布尔代数的方式将人类的思维用数学的方式表达出来,1和0成为了计算机中最小单位。查尔斯·桑德斯·皮尔士通过电子管将电和布尔代数结合起来,预示着计算机开始孕育。纵观历史长河,计算机未出生前就尽力了长达 70 多年的孕育,其中有各种不同的科学家重要的贡献。直到1946年约翰·冯·诺依曼为军方制造出计算弹道的 ENIAC,计算机从此诞生。
继电器(约瑟夫·亨利,1830年8月)
电磁感应(法拉第,1831年10月17日)
电(特斯拉)
摩尔斯电码(摩尔斯,1839年)
布尔代数(布尔)
与或非
逻辑门(查尔斯·桑德斯·皮尔士,1886)
电子管(真空管)(李‧福勒斯特,1907)
晶体管
二进制
里德·所罗门码
加法器
ENIAC(约翰·冯·诺依曼,1946年2月)
互联网起源
有了计算机还不能构成网络,互联网的鼻祖阿帕网也是经历了长达20年的历史,通过众多计算机专家、科学家以及工程师的努力才完成,当时阿帕网是冷战孕育的产物,还没有民用起来。1993蒂姆·伯纳斯·李发明了第一个网页浏览器,此刻互联网时代拉开序幕。
ARPANET(阿帕网,美国国防部高级研究计划管理局)1969-1990
人工智能专家:约瑟夫·利克莱德
鲍勃·泰勒
拉里·罗伯茨(《资源共享的电脑网络》)
雷纳德·克兰罗克(《通讯网络》)
道格拉斯·恩格尔巴特(鼠标发明者)
伊凡·苏泽兰(计算机图形学之父,虚拟现实之父)
温顿·瑟夫和鲍勃·卡恩(TCP/IP 协议)(NCP 协议1982 停用)
WWW 万维网(World-Wide Web)1991
蒂姆·伯纳斯·李 HTTP 协议,第一个网页浏览器:http://info.cern.ch/
前端简史
下面是20多年的前端技术发展轨迹,当然还有很多很多没有标注在时间线上(未来会整理一份更加想尽的时间线),每个时代都有自己的特征,当然互联网技术的发展也依靠商业模式的发展,众多工程师的努力,让我们跨越历史,看看前端几乎的发展:https://www.rafandraolshop.com
混沌时代
在互联网发展初期,无论是互联网产品和基于互联网的商业模型都没有出现,它对人们来说非常非常新鲜,只有少数人基于它做一些开发,个人网页是或许是初期的应用形态,PHP 作为最古老的互联网开发工具,至今为止也有很多公司和个人在使用。当然作为互联网这个新鲜而又充满想象的境地,各大计算机行业具体也嗅到了它的味道,微软公司率先推出了 ASP,之后的3年 Sun 公司也推出了 JSP。当时的产品和商业模式并不成熟,业务也不复杂,前端代码和后端代码没有清晰的界限,作为网页工程师,他们在页面上链接数据库,在页面上组合 HTML,在页面上写 JS 交互,前后端处于混沌状态。作为互联网发展初期,人们可以跨越千里,看到他人或公司的介绍网站,这已经是非常神奇的事情了。
1993 HTML
1995 PHP (Personal Home Page Tools)
1996 ASP
1999 JSP
混合时代
随着时间的发展,人们希望通过互联网更快的获取到更多的信息,此时搜索引擎和门户网站的出现让互联网成为一个可以赚钱的时代,适合互联网的商业模式也开始得到逐步证明。个人网站、公司企业网站越来越多业务也越来越复杂,为了解决工程的复杂度,微软公司和SUN公司先后用各自 MVC 模式将试图层和逻辑层解藕出来,前端也逐步开始形成。jQuery 的出现让前端开发更加的容易,它提供了整套的工具来解决 HTML 的操作。商家为了吸引人们的眼球,网站的表现形式开始从单纯的文字图片变得和用户更有交互,富客户端也逐步开始。
2002 asp.net
2002 spring
spring mvc
2005 prototype.js
2005 dojo
2006 jQuery
2006 yui
2006 ext
2006 sass/scss
2006 gwt
2007 .net mvc
前端分离时代(移动互联网)
2007 年乔布斯将 iPhone 展示给众人,移动互联网带来了巨大商机,各大商家纷纷转战移动端,丰富多样的 APP&H5 让用户随时随地获取到各种信息,和远在万里的人们沟通交流,也能通过发达的物流得到自己想要的事物,世界越来越小,人们的距离越来越近。为了完成复杂的交互逻辑,互联网前端技术也彻底的从后端分离开来。以 Google 为首的 Angular 前端 MVVM 框架,让复杂的前端逻辑更加容易开发,再借助各个自发组织和互联网公司研发出来的构建工具,让前端越来越工程化,越来越能够应付更加复杂的业务场景。这个时代出现过很多优秀的前端框架,它们让前端丰富多彩。
2008 github
2009 less
2009 angular
2009 underscore
2009 commonJS
2009 node.js
2010 npm
2010 requirejs
2010 backbone.js
2010 knockoutjs
2010 stylus
2010 three.js
2010 zepto (2016)
2010 jquerymobile
2010 uglifyjs
2011 d3.js
2011 emberjs
2011 seajs
2011 browserify
2011 phonegap/cordova
2012 bower
2012 yeoman
2012 grunt
前后端融合时代
移动互联网继续蓬勃发展,大型手游、共享经济、视频社交各种应用层出不穷,但是大家同样面临这一个问题————跨平台,Web、iOS、Android 等不同终端,导致开发团队异常的冗余,为了适应各端开发成本成倍提高,当然之前已经有过 Hybrid 的方式来解决此问题,但是还是不够彻底。以 Facebook 为首推出 React Native 通过 Web 的方式开发 App,另外 Vue2、Angular2 借助于 Nodejs 解决了 SSR 让前后端慢慢融合,从前端 App、Web到服务端全用统一语言或者框架来解决,让开发成本随之降低起来。当然 Google 也是嗅到了跨平台的未来,今年出来搞事情,推出重量级产品 Flutter 用另一种不同的方式来解决跨平台,从此前后端融合的大前端时代来临。https://www.strhockey.com
2012 webpack
2013 react
2016 next
2014 gulp
2014 babel
2015 react native
2016 yarn
2016 angular2
2016 vue2
2016 nuxt
2017 mini program
2018 flutter
〖坚持的一俢〗
作者:一俢
链接:https://www.imooc.com/article/284469
来源:慕课网
本文原创发布于慕课网 ,转载请注明出处,谢谢合作