文档章节

JSP + AjaxAnywhere页面开发规范

_凤求凰_
 _凤求凰_
发布于 2011/07/15 08:53
字数 1098
阅读 1197
收藏 4

JSP + AjaxAnywhere页面开发

1. 开发工具

       AJAX框架:AjaxAnywhere,最新版本1.1.0.6 , http://ajaxanywhere.sourceforge.net/

      2. 开发规范

2.1 概述

“JSP + AjaxAnywhere” 的结合开发,是为了在普通JSP应用中增加AJAX特性,从而改善用户体验,提高应用性能。

       AjaxAnywhere能于JSP很好结合。对于一个普通JSP 应用,要使用 AjaxAnywhere框架在一些特定功能中增加AJAX特性,只需对JSP页面做简单修改,基本不需要进行Javascript 编程,个别场合只需要按规范添加少量Javascript 代码。

       AjaxAnywhere + JSP 的结合与 AjaxAnywhere +JSF 的结合,在原理上是一致的, 但在使用上略有不同。对于二者的不同,可对照《JSF+Ajax页面开发规范》,根据具体情形的不同,可以选择不同的组合进行开发。这里的JSP指的是不包括JSF内容的简单JSP页面。

 

2.2 规范

对于一个普通JSP页面,需要做以下修改。

2.2.1引入ajaxanywheretaglib

<%@ taglib uri="http://ajaxanywhere.sourceforge.net/" prefix="aa" %>                  

 依照习惯 prefix定义为aa.

2.2.2 引入ajaxanywhere客户端脚本(Javascript

                    <script src="js/aa/aa.js"></script>                              

 

说明:aa.js AjaxAnywhere框架的客户端脚本库,对AJAX 特性进行了很好的封装。开发人员无须直接操作XmlHttpRequest

AjaxAnywhere客户端的核心类为 AjaxAnywhere ,其每一个实例代表一个AJAX处理器。aa.js中定义了一个缺省的AjaxAnywhere实例, 实例名为ajaxAnywhere iddefault

2.2.3 form 属性的修改

如果要对form提交增加AJAX支持,需要注意。在form标签中,必须包含action属性,但可以为空,name属性,method属性为post,然后按正常方式书写表单项目。

例如:

<form action="clientSide.jsp" name="main" method="post">           

2.2.4定义ajax zone(动态更新区域)

      需要单独刷新的部分在jsp页面中使用tag:

             <aa:zone name="<zoneName>"> </aa:zone>                          

括住需要更新的范围。

 例如:

<aa:zone name="zone1">

        <font color="white">     <br>Test refresh zone<br>

              <%=new Date()%><br>

        </font>

</aa:zone>

<aa:zone/> 标记是用于在JSP页面中增加AJAX特性支持,要对JSF组件增加AJAX 特性支持,需要使用 <aa:zoneJSF/> 标记。

namezone Tag的必填属性,用于在一个JSP页面内唯一标识一个动态更新的区域。 一个页面可定义多个zone区域。

该标识的命名请遵循java变量命名规则。

 

2.2.5 修改表单的提交行为

表单的提交部分有两种,根据后台需要可以不同对待。

1 通过get 方式发出的请求采用AjaxAnywhere.getAJAX()方法

例如:<input type="button" value="click me" onclick="ajaxAnywhere.getAJAX();">

2)  通过post方式发出的请求请采用 ajaxAnywhere.submitAJAX() 方法

例如:<input type="button" value="click me" onclick="ajaxAnywhere.submitAJAX();">

 

表单中的“提交”按钮,type需定义为 button ajaxAnywhere.getAJAX()和ajaxAnywhere.submitAJAX() 会自动处理表单数据的提交。作为与server交互的所需识别的信息头,路径(action,数据由ajaxanywhere自行包装。

作为server端反馈部分,反馈的数据为xml类型,AjaxAnywhere客户端处理器最终将替换<aa:zone name="<zoneName>"></aa:zone> 中的全部内容,开发人员不需要进行其他编码处理。

 

 

另外一种方式是, 从外部给按钮增加 Ajax异步提交的效果:

<SCRIPT language="javascript" type="text/javascript">     

        //ajaxAnywhere.formName="myform";  如果页面只有一个Form此行可以不要

        ajaxAnywhere.substituteFormSubmitFunction();

</SCRIPT>   

例如, 为表单中所有 submit image类型按钮增加Ajax 特性:

 

例如, 为表单中特定按钮增加Ajax 特性

<SCRIPT language="javascript" type="text/javascript">     

        ajaxAnywhere.formName="myform";  //如果页面只有一个Form此行可以不要

        ajaxAnywhere.substituteFormSubmitFunction();

        

        var ajaxButtons = new Array();

        ajaxButtons[0] = document.getElementById("btn_new");

        ajaxButtons[1] = document.getElementById("btn_run");   

        

        ajaxAnywhere.substituteSubmitButtonsBehavior(true, ajaxButtons);

2.2.6 服务器端代码:

2.2.6.1    指定Ajax 刷新区域

          要刷新<aa:zone/> 区域, 必须在服务器端代码中指定要刷新的区域. 一般有两种方式: JSP中指定, 和在 Java代码中指定:

       JSP中指定, 例如:

<%

    if(AAUtils.isAjaxRequest(request)) AAUtils.addZonesToRefresh(request,"zoneResList");

%>

 

 

 

 


一般放在JSP的顶部.

     一般放在JSP的顶部.

    

       Java代码中指定, 通常是Web框架的控制器(Controller)代码中, Struts中是XXXAction类的方法中, JSF 中是 XXXFace 类的方法中. 例如:

protected ActionForward doCreate(ActionMapping actionMapping,

                     ActionForm actionForm, HttpServletRequest request,

                     HttpServletResponse response, User user) throws Exception {

              ……….. 

              request.setAttribute(WebConstant.PAGE_ATTRIBUTE_MESSAGE, "保存成功!");

              request.setAttribute(CMSConstant.BUTTON_SAVE_DISABLED, "TRUE"); // 屏蔽保存按钮

              /* 刷新按钮区域 */

              if (AAUtils.isAjaxRequest(request)) {

                     AAUtils.addZonesToRefresh(request, "zoneButton");

              }

              return (actionMapping.findForward("new"));

 

2.2.6.2     

© 著作权归作者所有

共有 人打赏支持
_凤求凰_

_凤求凰_

粉丝 32
博文 45
码字总数 18630
作品 1
海淀
架构师
私信 提问
action获取不到参数

项目是有webservice,tiles,ajaxanywhere,struts2,ibties,spring等 web.xml: myorder index.jsp /axis2-web/index.jsp AjaxAnywhere org.ajaxanywhere.AAFilter AjaxAnywhere *.do org.a......

二号铺
2013/08/04
516
0
本人java菜鸟一枚,今天刚写好求职简历,专业技能怎么能写的有层次感呢!~谢谢了

1. 熟练掌握J2SE的基本语法规则,掌握冒泡,二分查找,双向链表,二叉树,生产者和消费者,终止,启动线程,文件复制等基本算法。 2. 熟练使用html、css会使用javaScript控制css样式和属性。...

祥林会跟你远走高飞
2012/10/04
7.6K
14
求兼职,本人目前javaWeb方向,爱好广泛。

RT,找兼职,钱无所谓。 下面是我找到目前这份工作的简历,欢迎骚扰。 • 扎实的JavaSE基础。良好的编程习惯。能够处理Java里面有一点复杂的的算法。(2、3年前SCJP 58分没过) • 熟练掌握 ...

Z_wenuw
2013/05/27
1K
13
jsp简介

Jsp简介 JSP技术使用Java编程语言编写类XML的tags和scriptlets,来封装产生动态网页的处理逻辑。网页还能通过tags和scriptlets访问存在于服务端的资源的应用逻辑。JSP将网页逻辑与网页设计和...

晨曦之光
2012/05/16
235
0
(JavaEE-07)JSP.md

JSP JSP全称是Java Server Pages,它和Servlet技术一样,都是SUN公司定义的一种用于开发动态Web资源的技术。JSP的编写就像编写HTML一样简单,但是与HTML不同的是,在JSP中,可以编写Java代码...

_-Leon-_
2014/07/04
0
0

没有更多内容

加载失败,请刷新页面

加载更多

为什么只有你每次提交代码,log里面会出现merge

http://www.cnblogs.com/Sinte-Beuve/p/9195018.html

踏破铁鞋无觅处
刚刚
0
0
如何学习大数据:spark发布程序

一、对于spark程序只是用于默认的spark包的情况 直接点击pcakage 将程序进行在linux当中进行发布 客户端模式:测试 spark-submit --class com.keduox.App \ --master yarn \ --deploy-mode ...

架构师springboot
刚刚
0
0
oracle job(定时任务)

创建 定时任务 job declare job number;BEGIN DBMS_JOB.SUBMIT( JOB => job, -- job任务的唯一标识(自动生成) WHAT => 'INSERT into TEXTL (id) VALUES(TEXT......

骑羊放狼灬
4分钟前
0
0
Spring声明式事务在抛出异常时不回滚(RollBack)

Spring声明式事务默认只在RuntimeException时Rollback(回滚),不当的try catch会导致事务不回滚。 spring事务默认运行时异常回滚,RuntimeException 配置时添加异常回滚 rollback-for="Th...

叶落花开
5分钟前
0
0
赋能时空云计算 阿里云数据库时空引擎Ganos上线

随着移动互联网、位置感知技术、对地观测技术的快速发展,时空信息已从传统GIS行业渗透到大众应用及各行各业。从静态POI(兴趣点)到APP位置信息,从导航电子地图到车辆行驶轨迹,从卫星影像...

阿里云云栖社区
7分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部