1 / 34
文档名称:

web前端发展简史.docx

格式:docx   大小:1,716KB   页数:34页
下载后只包含 1 个 DOCX 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

web前端发展简史.docx

上传人:文艺人生 2022/7/12 文件大小:1.68 MB

下载得到文件列表

web前端发展简史.docx

文档介绍

文档介绍:web前端发展简史
Web前端发展简史
有人说“前端开发”是IT界最容易被误解的岗位,这不是空穴来风。如果你还认为前端只是从美工那里拿到切图, JS和CSS一番乱炖,难搞的功能就去网上信手拈来,CtrlC + Ctrl V的话,利用frameset和iframe这两个标签。某一大块有独立功能的界面写到一个HTML文件,然后在主界面里面把它当作一个frame来载入,一般的B/S系统集成菜单的方式都是这样的。是不是觉得很熟悉?对的,现在大多公司的内部系统正是这个
时代的产物。
此外,还出现了一些基于特定浏览器的客户端组件技术,比如IE浏览器的HTC(HTML Component)。这种技术最初是为了对已有的常用元素附加行为的,后来有些场合也用它来实现控件。,使用这种技术提供了树形列表,日历,选项卡等功能。HTC的优点是允许用户自行扩展HTML标签,可以在自己的命名空间里定义元素,然后,使用HTML,JavaScript和CSS来实现它的布局、行为和观感。这种技术因为是微软的私有技术,所以逐渐变得不那么流行。Firefox浏览器布其后尘,也推出过一种叫XUL的技术,也同样没有流行起来。
铁器时代
这个时代的彗星是Ajax的出现以及JS基础框架
的兴起。
AJAX
AJAX其实是一系列已有技术的组合,早在这个名词出现之前,这些技术的使用就已经比较广泛了,GMail因为恰当地应用了这些技术,获得了很好的用户体验。由于Ajax的出现,规模更大,效果更好的Web程序逐渐出现,在这些程序中,JavaScript代码的数量迅速增加。出于代码组织的需要,“JavaScript框架”这个概念逐步形成,当时的主流是Prototype和Mootools,两者各有千秋,提供了各自方式的面向对象组织思路。
JavaScript基础框架
Prototype框架主要是为JavaScript代码提供
了一种组织方式,对一些原生的JavaScript类型提供了一些扩展,比如数组、字符串,又额外提供了一些实用的数据结构,如:枚举,Hash等,除此之外,还对dom操作,事件,表单和Ajax做了一些封装。
Mootools框架的思路跟Prototype很接近,它对JavaScript类型扩展的方式别具一格,所以在这类框架中,经常被称作“最优雅的”对象扩展体系。
从这两个框架的所提供的功能来看,它们的定位是核心库,在使用的时候一般需要配合一些外围的库来完成。
倚天不出,谁与争锋?除以上两者以外,还有YUI,jQuery等,JavaScript基础框架在这个时代算得上是百花齐放,但是时间已经证明,真正
的王者是jQuery。
jQuery与其他的基础框架都有所不同,它着眼于简化DOM相关的代码。例如:
DOM的选取
jQuery提供了一系列选择器用于选取界面元素,在其他一些框架中也有类似功能,但一般没有它简洁而强大。
$("*")//选取所有元素
$("#lastname")//选取id为lastname的元素
$(".intro")//选取所有class="intro"的元素
$("p")//选取所有<p>元素
$(".")//选取所有 class="intro"且class="demo"的元素
链式表达式
在jQuery中,可以使用链式表达式来连续操作DOM,如果不使用链式表达式,可能需要这么写:
var neat = $("");
("ohmy");
("slow");
但是有了链式表达式,一行代码就可以搞定:
$("").addClass("ohmy").show("slow");
除此之外,jQuery还提供了一些动画方面的特效代码,也有大量的外围库,比如jQuery UI这样的控件库,jQuery mobile这样的移动开发库等。
农业时代
这个时代的标志性事件是模块加载规范(AMD以及CMD)的出现。
铁器时代出现的基础框架提供了代码的组织能力,但是未能提供代码的动态加载能力。动态加载JavaScript为什么重要呢?因为随着Ajax的普及,jQuery等辅助库的出现,Web上可以做很复杂的功能,因此,单页面应用程序(SPA,Single Page Application)也逐渐多了起来。
单个的界面想要做很多功能,需要写的代码是会比较多的,但是,并非所有的功能都需要在界面加载的时候就全部引入,如果能够在需要的时候才加载那些代码,就把加载的压力分担了,在这个背景下,出现了一些用于动态加载JavaScript的框架,也出