ExtJs + Struts2 + JSON 程序总结

本文介绍如何实现ExtJS前端框架与Struts2后端框架的数据交互,重点讲解了JSON数据格式的使用及配置过程。从Hibernate实体映射到Struts2的Action处理,再到ExtJS前端展示,提供了完整的示例代码。

  最近一直都在看EXTJS的东西,然后自己实践了下,界面倒是蛮漂亮的,但是一旦涉及到与服务器端进行数据互动麻烦就出来了,本来下了个例子确发现是用DWR的,觉得我既然用了STRUTS2作为MVC的框架,我觉得这个框架还是很不错的,觉得还是把EXTJS整合到一起更好些,找了相关的资料,跟着前辈做了下例子,发现完全不是那么回事,只好自己慢慢摸索,终于把数据交互的问题解决了,所以记录之以便查阅!
       还是从底层开始说吧,拿最经典的例子来解说吧,订单和客户的关系显然是n:1的关系,我hibernate不是用的声明方式所以就用的xml方式做的那么相应的hbm.xml文件如下:
       ORDER.XML 

None.gif<?xml version="1.0"?>
None.gif
<!DOCTYPE hibernate-mapping PUBLIC 
None.gif    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
None.gif    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"
> 
None.gif       
<hibernate-mapping>
None.gif       
<class name="com.model.Order"  table="t_order" lazy="false">
None.gif           
<id name="orderId" column="OrderId">
None.gif               
<generator class="uuid.hex" />
None.gif           
</id>
None.gif           
<property name="name" column="Name" type="string" />
None.gif           
<property name="desn" column="Desn" type="string"/>
None.gif           
<property name="booktime" column="Booktime" type="string"/>
None.gif           
<property name="company" column="Company" />
None.gif           
<many-to-one lazy="false" name="custom" column="CustomId" class="com.model.Customer" />
None.gif       
</class>
None.gif   
</hibernate-mapping>
        CUSTOM.XML
None.gif<?xml version="1.0"?>
None.gif
<!DOCTYPE hibernate-mapping PUBLIC 
None.gif    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
None.gif    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"
> 
None.gif   
<hibernate-mapping>
None.gif       
<class name="com.model.Custom"  table="t_custom" lazy="false">
None.gif           
<id name="customId" column="Id">
None.gif               
<generator class="uuid.hex" />
None.gif           
</id>
None.gif           
<property name="customName" column="Name" type="string" />
None.gif       
</class>
None.gif   
</hibernate-mapping>

        相应的MODEL的JAVA我就不写了,只是做个例子而已,呵呵!相应的DAO SERVICE 我都不写了,这个不是我讨论的范围,那么我想在页面上显示所有的信息,那么在OrderAction中我定义了一个getAllOrder的方法,然后通过struts2配置action让EXTJS与服务器数据进行数据交互。因为EXTJS是支持JSON数据格式的,所以我用了JSON-LIB(json-lib-2.2.1-jdk15.jar)这个东东,它还依赖另外的3个包:commons-beanutils-1.7.1-20061106.jar,commons-collections-3.2.1.jar,ezmorph-1.0.4.jar。好了万事俱备只欠东风了,我的getAllOrder方法如下:
None.gifimport java.text.DateFormat;
None.gif
import java.text.ParseException;
None.gif
import java.text.SimpleDateFormat;
None.gif
import java.util.Date;
None.gif
import java.util.List;
None.gif
import net.sf.json.*;
None.gif
//具体的那些serivce的包引入我就省略了
None.gif
public class OrderAction extends ActionSupport
ExpandedBlockStart.gifContractedBlock.gif
dot.gif{
InBlock.gif   
private static final long serialVersionUID = -5092865658281004791L;
InBlock.gif    
private IOrderSerivce orderSerivce;
InBlock.gif    
private String jsonString;//这个就是中转站了
InBlock.gif
    private List<Order> orderList;//这个是数据链表
InBlock.gif
    private int totalCount;//这个是extjs用来分页
InBlock.gif
     public String getJsonString()
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        
return jsonString;
ExpandedSubBlockEnd.gif    }

InBlock.gif     
public void setJsonString(String jsonString)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        
this.jsonString = jsonString;
ExpandedSubBlockEnd.gif    }

InBlock.gif    
public int getTotalCount()
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        
return totalCount;
ExpandedSubBlockEnd.gif    }

InBlock.gif    
public void setTotalCount(int totalCount)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        
this.totalCount = totalCount;
ExpandedSubBlockEnd.gif    }

InBlock.gif    
public List<Air> getOrderList()
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        
return orderList;
ExpandedSubBlockEnd.gif    }

InBlock.gif    
public void setOrderList(List<Order> orderList)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        
this.orderList = orderList;
ExpandedSubBlockEnd.gif    }

InBlock.gif    
public void setOrderSerivce(OrderSerivce orderSerivce)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        
this.orderSerivce = orderSerivce;
ExpandedSubBlockEnd.gif    }

InBlock.gif    
public String getAllAir()
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        orderList 
= orderSerivce.getOrderAll();
InBlock.gif        
this.setTotalCount(orderList.size());
InBlock.gif        
InBlock.gif        JSONArray array 
= JSONArray.fromObject(orderList);
InBlock.gif
//哈哈,就是在这里进行转换的
InBlock.gif
        this.jsonString = "{totalCount:"+this.getTotalCount()+",results:"+array.toString()+"}";
InBlock.gif    
return SUCCESS;
ExpandedSubBlockEnd.gif    }

ExpandedBlockEnd.gif}
        接下来再是什么,哦,是的,应该是STRUTS的配置了,哈哈
None.gif<!DOCTYPE struts PUBLIC
None.gif    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
None.gif    "http://struts.apache.org/dtds/struts-2.0.dtd"
>
None.gif
None.gif
<struts>
None.gif      
<package name="order" extends="struts-default">
None.gif
<action name="getAllOrder" class="orderAction" method="getAllOrder">
None.gif            
<result name="success" >jsondata.jsp</result>
None.gif        
</action>
None.gif      
</package>
None.gif
</struts>
        好的,看到jsondata.jsp了么,这里就是要放数据的地方,看看是什么吧!
ExpandedBlockStart.gifContractedBlock.gif<%dot.gif@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
ExpandedBlockStart.gifContractedBlock.gif
<%dot.gif@ taglib prefix="s" uri="/struts-tags" %>
None.gif
<s:property value="jsonString" escape="false" />
        是的,就是这么简单的一个代码!终于要到前台了,该露脸了,呵呵,前台代码最关键的也就是JS代码,那么我也就只贴JS了相信大家看过后都会自己弄清楚的!
ExpandedBlockStart.gifContractedBlock.gif/**//*
InBlock.gif * Ext JS Library 2.1
InBlock.gif * Copyright(c) 2006-2008, Ext JS, LLC.
InBlock.gif * licensing@extjs.com
InBlock.gif * 
InBlock.gif * http://extjs.com/license
ExpandedBlockEnd.gif 
*/

None.gif
None.gif
ExpandedBlockStart.gifContractedBlock.gifExt.onReady(
function()dot.gif{
InBlock.gif    Ext.BLANK_IMAGE_URL 
= 'ext/resources/images/default/s.gif'; 
InBlock.gif    Ext.QuickTips.init();
InBlock.gif    
var xg = Ext.grid;
InBlock.gif    
//这里就是设置解析格式的地方,一定要和你的Model一样,要不然可是什么都得不到哦~~~~
ExpandedSubBlockStart.gifContractedSubBlock.gif
    var rd = new Ext.data.JsonReader(dot.gif{
InBlock.gif                
//总记录数
InBlock.gif
                totalProperty: 'totalCount', 
InBlock.gif               
//哪儿是数据的头,可以看action里面是怎么定义数据格式的,这里就是如何解析的           
                    root: 'results', 
InBlock.gif
                //有那些字段呢?
InBlock.gif
                fields:[
ExpandedSubBlockStart.gifContractedSubBlock.gif                         
dot.gif{name:'orderId'},
                                      {name:'desn'},
ExpandedSubBlockStart.gifContractedSubBlock.gif                         
dot.gif{name:'booktime'},
ExpandedSubBlockStart.gifContractedSubBlock.gif                         
dot.gif{name:'company'},
ExpandedSubBlockStart.gifContractedSubBlock.gif                         
dot.gif{name:'name'},
InBlock.gif                            
//这里就是对custom对象进行映射的地方                        
                                      {name:'customId' ,mapping:'custom.customId'},
ExpandedSubBlockStart.gifContractedSubBlock.gif                         dot.gif{name:'customName',mapping:'custom.customName'}
InBlock.gif                         ]
ExpandedSubBlockEnd.gif                                     }
);
ExpandedSubBlockStart.gifContractedSubBlock.gif     
var ds = new Ext.data.Store(dot.gif{
InBlock.gif                                    proxy: 
new Ext.data.HttpProxy
ExpandedSubBlockStart.gifContractedSubBlock.gif(
dot.gif{url: 'getAllOrder.action',method:'POST'}),//Url很关键,我就是因为没配好这个,POST方法很重要,你可以省略,让你看下错误也行的!耽误了一大堆时间!
InBlock.gif
                                    reader:rd
ExpandedSubBlockEnd.gif                                }
);
InBlock.gif     ds.load();
InBlock.gif     
var sm =new xg.CheckboxSelectionModel(); //CheckBox选择列
InBlock.gif
     var cm =new xg.ColumnModel([
InBlock.gif                                  
new Ext.grid.RowNumberer(), //行号列 
InBlock.gif
                                  sm,
ExpandedSubBlockStart.gifContractedSubBlock.gif                                  
dot.gif{id:'orderId',header: "订单号", dataIndex: 'name'},                           dot.gif{header: "订单时间",   dataIndex: 'booktime'},
ExpandedSubBlockStart.gifContractedSubBlock.gif                                  
dot.gif{header: "订单公司", dataIndex: 'company'},
ExpandedSubBlockStart.gifContractedSubBlock.gif                                  
dot.gif{header:"客户姓名",dataIndex:'customName'}
InBlock.gif                                 ]);
InBlock.gif                                 cm.defaultSortable 
= true;
InBlock.gif    
////////////////////////////////////////////////////////////////////////////////////////
InBlock.gif
    // OrderGrid 
InBlock.gif
    ////////////////////////////////////////////////////////////////////////////////////////
InBlock.gif

ExpandedSubBlockStart.gifContractedSubBlock.gif    
var ordergrid = new xg.GridPanel(dot.gif{
InBlock.gif                                  ds: ds,
InBlock.gif                                  sm: sm, 
InBlock.gif                                  cm: cm, 
InBlock.gif                                  width:
1000,
InBlock.gif                                  height:
500,
InBlock.gif                                  frame:
true,
InBlock.gif                                  title:'Framed 
with Checkbox Selection and Horizontal Scrolling',
InBlock.gif                                  iconCls:'icon
-grid',
InBlock.gif                                  renderTo: document.body
ExpandedSubBlockEnd.gif                                 }
);
InBlock.gif    ordergrid.render();
InBlock.gif
ExpandedBlockEnd.gif}
);


转载于:https://www.cnblogs.com/lxJack/archive/2011/06/03/2071947.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值