您的位置: 首页 > 技术文档 > 网络编程 > 用 AjaxTags 简化 Ajax 开发
历数Firefox2.0对XML处理的改进 回到列表 Dojo Javascript 编程规范
 用 AjaxTags 简化 Ajax 开发

作者:Daniel Wintschel 时间: 2007-11-26 文档类型:转载 来自:IBM developerWorks

第 1 页 用 AjaxTags 简化 Ajax 开发 [1]
第 2 页 用 AjaxTags 简化 Ajax 开发 [2]
第 3 页 用 AjaxTags 简化 Ajax 开发 [3]
第 4 页 用 AjaxTags 简化 Ajax 开发 [4]
第 5 页 用 AjaxTags 简化 Ajax 开发 [5]

选择框更新并进一步查看 JSP 标记语法

现在,让我们来看看这个应用程序为您完成所有任务的那些内容:AjaxTags JSP 标记库的实际使用。清单 4 取自同一个文件(dropdown.jsp):

清单 4. AjaxTag JSP 标记库示例:ajax:select 标记

<ajax:select
  baseUrl="${contextPath}/dropdown.view"
  source="make"
  target="model"
  parameters="make={make}"
  preFunction="initProgress"
  emptyOptionName="Select model"
  postFunction="resetProgress"
  errorFunction="reportError" />

在仔细研读清单 4 中的大块代码之前,请注意这段代码:${contextPath}。要消除混淆,需要指出这实际是一个使用 EL(表达式语言)进行的变量设置,在 header.jsp 中定义,如清单 5 所示:

清单 5. header.jsp 中的 contextPath 变量定义

<c:set var="contextPath" scope="request">
   ${pageContext.request.contextPath}</c:set>

我着重提到它,是为了让您能够清楚地看到 ${contextPath} 变量是如何被解析的。如果用 Java 编写,则其值会是 pageContext.getRequest().getContextPath() 的对等物。基于我的配置,${contextPath} 变量将是 http://localhost:8080/ajaxtags-1.3-beta-rc6-1 的值。

现在,再回到 清单 4,注意到为了向服务器进行异步回调,您必须要知道这个请求的 URL。AjaxTag 需要这个 baseUrl 参数,它是 ID 为 make 的选择框发生更改事件时所需异步请求的那个 URL。

知道了 ${contextPath} 的值后,就可以看到将要请求的 baseUrl 为 http://localhost:8080/ajaxtags-1.3-beta-rc6-1/dropdown.view。

baseUrl 后面还有 source 和 target。这些参数代表了所处理的 HTML 元素的 ID。在本例中,处理了两个选择框:一个包含汽车制造商,另一个包含汽车模型。包含汽车制造商的选择框是源,包含汽车模型的选择框则是目标。

parameters 参数(请参见 清单 6)表示的是应该传递到被请求 URL 的一些额外参数:

清单 6. parameters 参数

parameters="make={make}"

请注意花括号内的语法为 make={make}。这就表明要将 make 的参数键追加到这个正被异步请求的 URL,而且作为数值,传递在相应的指定 HTML 元素中找到的值(基于 ID)。所以在这个示例中,后台的 JavaScript 将会用 make 的 ID 来获得这个 HTML 元素、获得该元素的值并将其作为 HTTP 请求的一部分传递。这听起来比实际的情况更容易让人混淆,所以让我们来看看最后的这个 URL,此 URL 在选择第一个选择框的内容时被请求(请参见 清单 7):

清单 7. 当用户从第一个选择框中选择 “Mazda” 时,所请求的 URL

http://localhost:8080/ajaxtags-1.3-beta-rc6-1/dropdown.view?make=Mazda

可以看到已经有一个参数被添加在 URL 的末尾,参数键是 make,而参数的值为 Mazda。

ajax:select 参数 preFunction、postFunction 和 errorFunction 是所编写的定制 JavaScript 函数的名称,这些函数在时间或条件合适时调用。在本例中,命名的方式很明显。preFunction 在 Ajax 请求之前执行;postFunction 在 Ajax 请求完成且收到响应之后执行,errorFunction 在出现问题(比如请求返回了 500 内部服务器错误或资源不存在消息等等)时执行。

最后一个参数 emptyOptionName 是选项的值,这个选项显示没有做出某个选择。在本例中,恢复默认状态。

出处:IBM developerWorks
责任编辑:moby

上一页 用 AjaxTags 简化 Ajax 开发 [3] 下一页 用 AjaxTags 简化 Ajax 开发 [5]

◎进入论坛网络编程版块参加讨论

相关文章 更多相关链接
静态页面分页的AJAX实现
Unobtrusive的Web开发
Ajax的小贴士
AJAX通用类:AJAXRequest v0.3
FLASH基础开发习惯
热门搜索:CSS Fireworks 设计比赛 网页制作 Dreamweaver Studio8 Flash
站点最新 站点最新列表
疯狂的程序员 第五十回
疯狂的程序员 第四十九回
疯狂的程序员 第四十八回
疯狂的程序员 第四十七回
疯狂的程序员 第四十六回
疯狂的程序员 第四十五回
疯狂的程序员 第四十四回
疯狂的程序员 第四十三回
疯狂的程序员 第四十二回
疯狂的程序员 第四十一回
栏目最新 栏目最新列表
火星人的耳机
公司正式宣布创业失败
用corelDEAW 12打造唇膏
二行代码解决全部网页木马
一行代码解决iframe挂马
Photoshop制作星空爆炸效果
CorelDraw 12打造休闲裤
Firework如何画特殊的切角图形
Firework打造韩式风格的手提袋
flash实例:打造佛光效果
>> 分页 首页 前页 后页 尾页 页次:4/51个记录/页 转到 页 共5个记录

蓝色理想版权申明:除部分特别声明不要转载,或者授权我站独家播发的文章外,大家可以自由转载我站点的原创文章,但原作者和来自我站的链接必须保留(非我站原创的,按照原来自一节,自行链接)。文章版权归我站和作者共有。

转载要求:转载之图片、文件,链接请不要盗链到本站,且不准打上各自站点的水印,亦不能抹去我站点水印。

特别注意:本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有,文章若有侵犯作者版权,请与我们联系,我们将立即删除修改。

本文现有 3 条评论 评分:- llllllllllllllllllll + 评分人数: 2 ,平均分: 5.00


xuye281 Publish at 2008-5-9 1:33:14 评分5
Wakfu
dan59 Publish at 2007-11-26 11:33:15
郁闷,不做JSP的,呵呵。想着还偷懒能不能实现的比较简单点呢,呵呵。
amtoni Publish at 2007-11-26 3:36:32 评分5
不错的文章
您的评论
用户名:  口令:
说明:输入正确的用户名和密码才能参与评论。如果您不是本站会员,你可以注册 为本站会员。
注意:文章中的链接、内容等需要修改的错误,请用报告错误,以利文档及时修改。
不评分 1 2 3 4 5
注意:请不要在评论中含与内容无关的广告链接,违者封ID
请您注意:
·不良评论请用报告管理员,以利管理员及时删除。
·尊重网上道德,遵守中华人民共和国的各项有关法律法规
·承担一切因您的行为而直接或间接导致的民事或刑事法律责任
·本站评论管理人员有权保留或删除其管辖评论中的任意内容
·您在本站发表的作品,本站有权在网站内转载或引用
·参与本评论即表明您已经阅读并接受上述条款
推荐文档 | 打印文档 | 评论文档 | 报告错误  
专业书推荐 更多内容
大师之路--Photoshop 完全解析
《超越CSS》新书上市
Don't Make Me Think 第2版
HTML与CSS入门经典(第7版)
《FLASH MX2004网站开发精粹》
《CSS入门经典》
《设计师谈网页设计思维》
作品集 更多内容

字号 最近的作品—COPPERHEAD 三星U3产品形象广告 网站设计 基金会网站设计 我们的寝室 無瞳 二七广场的这些孩子