返回列表 回复 发帖

Ajax适用场景


$ J) a7 x" x4 \/ F  ?
+ S0 D' ^, _6 P: M$ z  oAjax已经成为大型网站所必有的技术。Ajax在网站的各个场景中,都可以看到。例如,
; s1 e, \) z; U$ n  P8 V校友录的登录借口;% e/ e. V" f; I* l% e: [0 {
Google输入关键字的文本框;
- k2 U/ o' M! P% y) _$ @" ~各大论坛上自动验证用户输入的数据的文本框。8 o) Z5 [" h. C+ {

4 B3 r- n& f* B4 v( Y; ~- r' x总起来,可以大致归纳为以下几类:
# A* |; _6 O: ^1 ` . L* B  J4 F. I8 ^4 x& w2 F. f
1.表单驱动的交互
7 o' A& x; L- p3 W# E 8 f) G1 K* N, g6 a7 u. ~6 |, j/ N
传统的表单提交,在文本框输入内容后,点击按钮,后台处理完毕后,页面刷新,再回头检查是否刷新结果正确。使用Ajax,在点击sunmit按钮后,立刻进行异步处理,并在页面上快速显示了更新后的结果,这里没有整个页面刷新的问题。例如校友录登录就是使用使用这种方式
" ?) a4 t& l+ Z4 K4 l8 m2 d & V" A; C! N7 E1 b" W6 G5 E
2.深层次的树的导航
4 ^, }( z$ _: @
% ]2 t( P2 v) z% P. R+ ~深层次的级联菜单(树)的遍历是一项非常复杂的任务,使用JavaScript来控制显示逻辑,使用Ajax延迟加载更深层次的数据可以有效的减轻服务器的负担。以前的对级联菜单的处理多数是这样的:为了避免每次对菜单的操作引起的重载页面,不采用每次调用后台的方式,而是一次性将级联菜单的所有数据全部读取出来并写入数组,然后根据用户的操作用JavaScript来控制它的子集项目的呈现,这样虽然解决了操作响应速度、不重载页面以及避免向服务器频繁发送请求的问题,但是如果用户不对菜单进行 操作或只对菜单中的一部分进行操作的话,那读取的数据中的一部分就会成为冗余数据而浪费用户的资源,特别是在菜单结构复杂、数据量大的情况下(比如菜单有 很多级、每一级菜又有上百个项目),这种弊端就更为突出。6 Y  [0 O: R! F7 F) ~' f
如果在此案中应用Ajax后,结果就会有所改观:在初始化页面时我们只读出它的第一级的所有数据并显示,在用户操作一级菜单其中一项时,会通过Ajax向后台请求当前一级项目所属的二级子菜单的所有数据,如果再继续请求已经呈现的二级菜单中的一项时,再向后面请求所操作二级菜单项对应的所有三级菜单的所有数据,以此类推……这样,用什么就取什么、用多少就取 多少,就不会有数据的冗余和浪费,减少了数据下载总量,而且更新页面时不用重载全部内容,只更新需要更新的那部分即可,相对于后台处理并重载的方式缩短了用户等待时间,也把对资源的浪费降到最低。例如Google的首页,收入不同的关键词,就会自动提示响应的关键字。
1 @+ X) N6 n- ^! w
3 J) g5 }  f7 O' j3.快速的用户与用户间的交流响应% f. R; {+ Y! W4 O, }# p# e
在众多人参与的交流讨论的场景下,最不爽的事情就是让用户一遍又一遍刷新页面以便知道是否有新的讨论出现。新的回复应该以最快的速度显示出来,而把用户从分神的刷新中解脱出来,Ajax是最好的选择。
2 }2 q6 l: T# U+ Q. N
6 ?' U1 n, E5 W5 h# {9 Y4.类似投票、yes/no等无关痛痒的场景
2 ]9 c0 f  q1 u, F: G3 `4 f  G0 d对于类似这样的场景中,如果提交过程需要达到40秒,很多的用户就会直接忽略过去而不会参与,但是Ajax可以把时间控制在1秒之内,从而更多的用户会加入进来。
6 b* c" B) K7 T  r; a0 |
) k" \, a8 D7 x2 A5.对数据进行过滤和操纵相关数据的场景: n/ v0 ^0 O7 }6 k- q* z2 Z
对数据使用过滤器,按照时间排序,或者按照时间和名称排序,开关过滤器等等。任何要求具备很高交互性数据操纵的场合都应该用JavaScript,而不是用一系列的服务器请求来完成。在每次数据更新后,再对其进行查找和处理需要耗费较多的时间,而Ajax可以加速这个过程。例如,新浪的邮箱就是采用了这些技术。, |8 a5 ]% Y7 m& t$ h

" i: M9 b+ J0 {) Z1 G; @3 s3 n6.普通的文本输入提示和自动完成的场景
$ l* b7 a  d) B% d2 a5 z$ y在文本框等输入表单中给予输入提示,或者自动完成,可以有效的改善用户体验,尤其是那些自动完成的数据可能来自于服务器端的场合,Ajax是很好的选择。这一点,Google做的最好。大家到Google的首页输入关键字,就会发现其优点
返回列表