在开发过程中,抽象成模型,定义规范是非常有必要的,不仅可以简化代码,提高开发效率,也为自己减少了不少麻烦。

在开发中,因为DWZ这块是我负责,由于代码琐碎,重复度高,没有抽象封装,没有定义规范,别人不清楚都来问我,导致我经常在解决相同的问题,所以我把DWZ中的信息回馈这块抽象封装成通用模型,便于使用,也减少了自己的麻烦。

DWZ是客户端框架,自然需要接收后台传来的消息,可能是异常信息,可能是成功信息。

返回信息是json格式,其中包括状态码、callbackType类型、navTabId等。

我把这些信息都封装在AjaxObject中。

AjaxObject.java

packagecom.dwz.util;

/**
*
* callbackType如果是closeCurrent就会关闭当前tab
*只有callbackType="forward"时需要forwardUrl值
*
*form提交后返回json数据结构statusCode=DWZ.statusCode.ok表示操作成功, 做页面跳转等操作.
* statusCode=DWZ.statusCode.error表示操作失败,提示错误原因.
*statusCode=DWZ.statusCode.timeout表示session超时,下次点击时跳转到DWZ.loginUrl
* {"statusCode":"200","message":"操作成功","navTabId":"navNewsLi","forwardUrl":"","callbackType":"closeCurrent"}
* {"statusCode":"300","message":"操作失败"}
* {"statusCode":"301","message":"会话超时"}
*
* @author <ahref="mailto:tcl_6688@163.com">tch</a>
* Version 1.0.0
* @since 2013-12-8 下午6:46:53
*/ publicclass AjaxObject {
//状态码
publicfinal static int STATUS_CODE_SUCCESS = 200;
publicfinal static int STATUS_CODE_FAILURE = 300;
publicfinal static int STATUS_CODE_TIMEOUT = 301;
publicfinal static int STATUS_CODE_FORBIDDEN = 403; //callbackType类型
publicfinal static String CALLBACK_TYPE_CLOSE_CURRENT = "closeCurrent";
publicfinal static String CALLBACK_TYPE_FORWARD = "forward"; privateint statusCode = STATUS_CODE_SUCCESS;
privateString message = "";
privateString navTabId = "";
privateString forwardUrl = "";
privateString rel = "";
privateString callbackType = CALLBACK_TYPE_CLOSE_CURRENT; publicAjaxObject() { } publicAjaxObject(String message) {
this.message= message;
} /**
* 构造函数
* @param statusCode
*/
publicAjaxObject(int statusCode) {
super();
this.statusCode= statusCode;
} /**
* 构造函数
* @param statusCode
* @param message
*/
publicAjaxObject(int statusCode, String message) {
super();
this.statusCode= statusCode;
this.message= message;
} /**
* 构造函数
* @param statusCode
* @param message
* @param callbackType
*/
publicAjaxObject(int statusCode, String message, String callbackType) {
this.statusCode= statusCode;
this.message= message;
this.callbackType= callbackType;
} /**
* 构造函数
* @param statusCode
* @param message
* @param forwardUrl
* @param rel
* @param callbackType
*/
publicAjaxObject(int statusCode, String message, String navTabId, String forwardUrl,
Stringrel, String callbackType) {
this.statusCode= statusCode;
this.message= message;
this.navTabId= navTabId;
this.forwardUrl= forwardUrl;
this.rel= rel;
this.callbackType= callbackType;
} /**
* 返回 statusCode 的值
* @return statusCode
*/
publicint getStatusCode() {
returnstatusCode;
} /**
* 设置 statusCode 的值
* @param statusCode
*/
publicAjaxObject setStatusCode(int statusCode) {
this.statusCode= statusCode;
returnthis;
} /**
* 返回 message 的值
* @return message
*/
publicString getMessage() {
returnmessage;
} /**
* 设置 message 的值
* @param message
*/
publicAjaxObject setMessage(String message) {
this.message= message;
returnthis;
} /**
* 返回 forwardUrl 的值
* @return forwardUrl
*/
publicString getForwardUrl() {
returnforwardUrl;
} /**
* 设置 forwardUrl 的值
* @param forwardUrl
*/
publicAjaxObject setForwardUrl(String forwardUrl) {
this.forwardUrl= forwardUrl;
returnthis;
} /**
* 返回 rel 的值
* @return rel
*/
publicString getRel() {
returnrel;
} /**
* 设置 rel 的值
* @param rel
*/
publicAjaxObject setRel(String rel) {
this.rel= rel;
returnthis;
} /**
* 返回 callbackType 的值
* @return callbackType
*/
publicString getCallbackType() {
returncallbackType;
} /**
* 设置 callbackType 的值
* @param callbackType
*/
publicAjaxObject setCallbackType(String callbackType) {
this.callbackType= callbackType;
returnthis;
} /**
* 返回 navTabId 的值
* @return navTabId
*/
publicString getNavTabId() {
returnnavTabId;
} /**
* 设置 navTabId 的值
* @param navTabId
*/
publicAjaxObject setNavTabId(String navTabId) {
this.navTabId= navTabId;
returnthis;
} publicstatic AjaxObject newOk(String message) {
returnnew AjaxObject(STATUS_CODE_SUCCESS, message);
} publicstatic AjaxObject newError(String message) {
returnnew AjaxObject(STATUS_CODE_FAILURE, message);
} publicstatic AjaxObject newTimeout(String message) {
returnnew AjaxObject(STATUS_CODE_TIMEOUT, message);
} publicstatic AjaxObject newForbidden(String message) {
returnnew AjaxObject(STATUS_CODE_TIMEOUT, message);
} publicstatic AjaxObject newRefreshNavtab(String navTabId, String message) {
AjaxObjectajaxObject = new AjaxObject(message);
ajaxObject.navTabId= navTabId;
returnajaxObject;
} publicstatic AjaxObject newRefreshRel(String rel, String message) {
AjaxObjectajaxObject = new AjaxObject(message);
ajaxObject.rel= rel;
returnajaxObject;
} publicstatic AjaxObject newForward(String forwardUrl) {
AjaxObjectajaxObject = new AjaxObject(CALLBACK_TYPE_FORWARD);
ajaxObject.forwardUrl= forwardUrl;
returnajaxObject;
} /**
* 转换成JSONObject,以便传到客户端显示
* @return
* @see java.lang.Object#toString()
*/
@Override
publicString toString() {
StringBufferbuffer = new StringBuffer();
buffer.append("{")
.append("\"statusCode\":\"" + statusCode +"\",")
.append("\"message\":\"" + message +"\",")
.append("\"navTabId\":\"" + navTabId +"\",")
.append("\"rel\":\""+ rel + "\",")
.append("\"callbackType\":\"" + callbackType +"\",")
.append("\"forwardUrl\":\"" + forwardUrl +"\"")
.append("}");
returnbuffer.toString();
} }

重点

通过AjaxObject的toString方法,将信息转换成JSONObject,返回到客户端显示

使用时,在Service中抛出异常,在Action中捕获异常

userService.java

public void addUser(User user) throws Exception {

//测试异常
if("tch".equals(user.getName())) {
thrownew Exception("已经存在该用户!");
}

userAction.java

publicvoid userSave(){
Stringmsg; try{
userDao.saveorupdate(user);
msg= AjaxObject.newOk("添加用户成功啦!").toString();
}catch (Exception e) {
msg= AjaxObject.newError(e.getMessage()).setCallbackType("").toString();
} //将处理信息发送到客户端
HttpServletResponseresponse=ServletActionContext.getResponse();
response.setCharacterEncoding("utf-8");
try{
PrintWriterout=response.getWriter();
out.print(msg);
out.close();
}catch (IOException e) {
e.printStackTrace();
}
}

效果图

DWZ (JUI) 教程(二):处理信息回馈的通用规范的更多相关文章

  1. DWZ (JUI) 教程 tree 控件的选中事件

    DWZ (JUI) 教程 tree 控件的选中事件 先简单说一下流程 第一步 当然是先定义好回调事件了 function checkCallback(json){ ........... ...... ...

  2. DWZ(JUI) 教程 左侧栏默认是关闭状态的问题

    DWZ(JUI) 教程 左侧栏默认是关闭状态的问题,初始化是全屏状态,只需简单处理就可以了 $(function(){ DWZ.init("dwz.frag.xml", { log ...

  3. DWZ (JUI) 教程 国际化问题(多语言/语言切换)

    DWZ 国际化也是比较简单的,网站的内容国际化和常规的项目国际化是一样的,不要做出特殊的调整. DWZ 自身框架的国际化,比如 翻页的上一页下一页等信息.这些信息都是在dwz.frag.xml 文件当 ...

  4. DWZ (JUI) 教程 DWZ中dialog层的刷新

    在DWZ开发过程中经常会遇到的一种情况就是:在navTab页面中通过a标签打开一个dialog,在dialog层进行操作后,需要对该dialog层进行必要的刷新操作. 1.首先讲一下思路: 在非dia ...

  5. DWZ (JUI) 教程 navTab 刷新分析

    navTab的刷新在doc文件里也有说明 首先 在form表单里指定好回调函数 * <form action="/user.do?method=save" onsubmit= ...

  6. DWZ (JUI) 教程 table 排序

    dwz排序是后台排序,不是前台的js排序,他的流程和搜索,分页是一样的,当你点击排序的按钮时,从新发送请求刷新当前的navTable 和 dialog. <th width="60&q ...

  7. DWZ (JUI) 教程 根据ID刷新 dialog

    reloadDialog:function(dialogId){ var dialog = $("body").data(dialogId); if(dialog){ $.pdia ...

  8. DWZ(JUI) 教程 中如何整合第三方jQuery插件

    Query插件一般是$(document).ready()中初始化 $(document).ready(function(){  // 文档就绪,初始化jQuery插件| });  // 或者或缩写形 ...

  9. DWZ(JUI) 教程 普通表单提交

    一类是普通的表单提交,另一类就是列表页面的表单提交,主要是用来查询搜索列表使用的.今天我就简单介绍一下前者. 这是官网上的普通列表页面, <div class="pageContent ...

随机推荐

  1. 我的Python成长之路---第三天---Python基础(12)---2016年1月16日(雾霾)

    四.函数 日常生活中,要完成一件复杂的功能,我们总是习惯把“大功能”分解为多个“小功能”以实现.在编程的世界里,“功能”可称呼为“函数”,因此“函数”其实就是一段实现了某种功能的代码,并且可以供其它代 ...

  2. 四级流水线的8bit加法器

    以流水线实现8bit 加法器. //date : 2013/8/23 //designer :pengxiaoen //function : module pipeline ( clock ,rese ...

  3. C++第13周(春)项目1 - 点、圆的关系

    课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759.内有完整教学方案及资源链接 [项目1 - 点.圆的关系](1)先建立一个P ...

  4. CheckBoxList控件

    主要介绍:自定义数据.绑定数据库数据.全选,取消全选. 这种方法是绑定已经给定(自定义)的字段(这种方法是绑定给定的值,就是在编写控件时给Text赋的值): 前台代码: <asp:CheckBo ...

  5. 嵌入式MCU开发群资源

     STM32CubeMX是一款图形化软件设置工具,允许使用图形化向导来生成C初始化代码.它是未来开发stm32系列产品的主流软件,是ST公司的主动原创,可以减轻开发工作,时间和费用.STM32Cube ...

  6. 在C++中使用C#编写的类2

    在那篇<在C#中使用C++编写的类>中我介绍了如何在C#中使用C++编写的类.可是由于C#在用户界面设计.数据库存储和XML文件读取等方面的优势,有时候也会出现要在C++中使用C#编写的类 ...

  7. Robot Framework与Web界面自动化测试学习笔记:定位到新窗口

    在页面操作中,有时会需要打开新的窗口(新的网页不在当前窗口显示,而是在新的tab页显示), 比如利用  window.open("newurl") 或者  <a href=& ...

  8. 基于Server-Sent Event的简单聊天室 Web 2.0时代,即时通信已经成为必不可少的网站功能,那实现Web即时通信的机制有哪些呢?在这门项目课中我们将一一介绍。最后我们将会实现一个基于Server-Sent Event和Flask简单的在线聊天室。

    基于Server-Sent Event的简单聊天室 Web 2.0时代,即时通信已经成为必不可少的网站功能,那实现Web即时通信的机制有哪些呢?在这门项目课中我们将一一介绍.最后我们将会实现一个基于S ...

  9. codeforces 264D Colorful Stones

    题目 题目来自于rng_58Orz. 算法 讨论某个状态\((x,y)\)是否可达,\(x\)是狐狸到达的石头,\(y\)是猫的. 题解说,如果满足以下条件,那么它就是可到达状态: \(t[0..y] ...

  10. inner join、left join、right join中where和and的作用

    inner join.left join.right join中where和and的作用 .内连接(自然连接): 只有两个表相匹配的行才能在结果集中出现 2.外连接: 包括  (1)左外连接 (左边的 ...