ExtJs+SpringMVC+ibatis 实现

通过学习springMVC ,下面是extjs 整合springmvc 和 ibatis 实现的一个gridpanel 的 增删改查以及动态分页:

目前将前提Extjs 代码 和 springMvc 的控制层(control)的实现为大家提供,其业务层的实现也是比较简单的只是借助于ibatis 实现数据操作。

<%@ page language="java" pageEncoding="UTF-8"%>

<html>

<head>

</head>

<title>spring mvc + extjs test</title>

 <link rel="stylesheet" type="text/css" href="${pageContext.request.contextPath}/extjs/resources/css/ext-all-gray.css" />

<script type="text/javascript" src="${pageContext.request.contextPath}/extjs/ext-all-dev.js"></script>

<script type="text/javascript" src="${pageContext.request.contextPath}/extjs/ext-lang-zh_CN.js"></script>

 

<script type="text/javascript">

 Ext.onReady(function(){

//分页条数

var itemsPerPage = 5;

var searchtext=null;

var bj=1;//区分新增修改标识

var store=Ext.create('Ext.data.Store', {//数据源

storeId:'simpsonsStore',

pageSize:itemsPerPage,//每页显示条数

fields:['emp_id', 'name', 'age'],

proxy: {

type: 'ajax',

url:'empList.do',

actionMethods: {  

           read: 'post'  

       },  

reader: {

type: 'json',

totalProperty : 'totalCount',//总条数

root: 'paginationDtos'// 数据根节点

}

}

});

//数据加载

store.load({

   params:{

    seachKey:searchtext,

       start:0,

       limit: itemsPerPage

   }

});

//常用grid

var grid=Ext.create('Ext.grid.Panel', {

title: '常用Grid',

store: store,//store

selModel:Ext.create('Ext.selection.CheckboxModel'),//checkbox

columns: [//列

{xtype: 'rownumberer'},

{ text: '编号',  dataIndex: 'emp_id' },

{ text: '姓名', dataIndex: 'name'},

{ text: '年龄', dataIndex: 'age' }

],

height: 400,

width: 800,

tbar:[{

xtype:'button',

//draggable:true,是否可以拖动

text:'新增',

handler:function(){

bj = 1;//标记为新增

win.setTitle("员工新增");

win.show();

 

}

},

{ xtype: 'tbseparator' },

{

text : '修改',

handler : function() {

var selection = grid.getSelectionModel().getSelection();

if(selection.length!=1){

Ext.MessageBox.alert("提示","请选择一条记录!");

return;

}

win.setTitle("员工修改");

formPanel.getForm().findField('name').setValue(selection[0].get("name"));

formPanel.getForm().findField('age').setValue(selection[0].get("age"));

win.show();

bj=2;//设置标记为修改

}

},

{ xtype: 'tbseparator' },

{

xtype:'button',

text:'删除',

handler:function(){

var selection = grid.getSelectionModel().getSelection();

if(selection.length !=1){

Ext.MessageBox.alert("提示","请选择一条记录!");

return;

}

       Ext.MessageBox.confirm("提示",'您是否确认删除?',function(e){

if(e=='yes'){

//调用删除方法

deleteEmpById(selection[0].get('emp_id'),store);

}

});

}

},

{

xtype: 'tbseparator'

},

{

xtype:'label',

text:'请输入关键词:'

},

{

xtype:'textfield',

id:'KeyWord'

},

{

text:'搜索',

handler:function(){

searchtext = Ext.getCmp("KeyWord").getValue();

//Ext.MessageBox.alert("提示",searchtext);

//grid.store.pageNum = 1;         //向后台传的页面

           //grid.store.seachKey = searchtext;   //给Store中的条件赋值,

           store.load({

            method : 'POST',

       params:{

        seachKey:searchtext,

           start:0,

           limit: itemsPerPage

       }

    });    //加载后显示第一页

}

],

bbar: [{

       xtype: 'pagingtoolbar',

       dock: 'bottom',

       store: store,

       //displayMsg:'显示第{0}条数据到{1}条数据,一共有{2}条',

       emptyMsg:"没有符合的数据",

       displayInfo: true

   }

],

renderTo:'gridPanel'

});

 

var formPanel=Ext.create('Ext.form.Panel',{

layout:'form',

height:400,

width:350,

frame:true,

items:[

{

xtype:'textfield',

fieldLabel:'姓 名',

name:'name',

allowBlank: false 

},

{

xtype:'numberfield',

fieldLabel:'年 龄',

name:'age',

width :250,

anchor: '100%',

maxValue: 200,

       minValue: 1,

allowBlank: false 

}],

buttons:[

{

xtype:'button',

text:'提交',

handler:function(){

if (formPanel.getForm().isValid()){

if(bj ==1){

addEmp(formPanel,win,store);

}else if(bj==2){

var selection = grid.getSelectionModel().getSelection();

    if(selection.length!=1 ){

    Ext.MessageBox.alert("提示","请选择一条记录!");

    return;

    }

    var id = selection[0].get("emp_id");

    updateEmp(id,formPanel,win,store)

   

}

}

 

}

 

},

{

xtype:'button',

text:'重置',

handler:function(){

formPanel.getForm().reset();

}

}]

 

});

 

Ext.define('windFrom',{

       extend:'Ext.window.Window',

       title: '新增/修改员工信息',

   height: 400,

   width: 350,

   layout: 'fit',

   buttonAlign: 'center' ,    

           closable: true ,     //是否可关闭

           collapsible: true ,  //是否可收缩

           draggable: true ,    

           resizable: false , 

           closeAction:'hide',

   modal:true,

   items: [formPanel],

   listeners:{

        hide:function(){

        formPanel.getForm().reset();

        }

       }

   });

 

var win=Ext.getCmp("windFromId");//获取win

 

   if(!win){

       win=Ext.create('windFrom');

   }

//定义员工新增函数

function addEmp(empForm,win,store){

Ext.Ajax.request({

url : 'empAdd.do',

headers: {'Content-Type':'application/json; charset=utf-8'},

jsonData : {

'name' : empForm.getForm().findField('name').getValue(),

'age' : empForm.getForm().findField('age').getValue()

} ,

success : function(response, opts) {

var result = Ext.decode(response.responseText);

if(result.success){

Ext.MessageBox.alert("提示",result.msg);

win.hide();

store.load();//数据重新加载

}else{

Ext.MessageBox.alert("提示",result.msg);

}

},

failure : function(response, opts) {

Ext.MessageBox.alert("提示","链接失败!");

}

});

}

 

//修改员工信息

function updateEmp(id,empForm,win,store){

Ext.Ajax.request({

url : 'updateEmp.do',

headers: {'Content-Type':'application/json; charset=utf-8'},

jsonData : {

'emp_id':id,

'name' : empForm.getForm().findField('name').getValue(),

'age' : empForm.getForm().findField('age').getValue()

} ,

success : function(response, opts) {

var result = Ext.decode(response.responseText);

if(result.success){

Ext.MessageBox.alert("提示",result.msg);

win.hide();

store.load();//数据重新加载

}else{

Ext.MessageBox.alert("提示",result.msg);

}

},

failure : function(response, opts) {

Ext.MessageBox.alert("提示","链接失败!");

}

});

}

//更加员工Id 进行删除

function deleteEmpById(id,store){

Ext.Ajax.request({

url : 'deleteEmp.do',

/*headers: {'Content-Type':'application/json; charset=utf-8'},

jsonData : {

'emp_id':id,

'name' : empForm.getForm().findField('name').getValue(),

'age' : empForm.getForm().findField('age').getValue()

} , */

params:{"id":id},

success : function(response, opts) {

var result = Ext.decode(response.responseText);

if(result.success){

Ext.MessageBox.alert("提示",result.msg);

win.hide();

store.load();//数据重新加载

}else{

Ext.MessageBox.alert("提示",result.msg);

}

},

failure : function(response, opts) {

Ext.MessageBox.alert("提示","链接失败!");

}

});

}

 

 

 

 

 

 });

 

 

</script>

<body>

<h1>Hello world</h1>

 

<h1>gridPanel</h1>

<p>这里列举了常用的 gridPanel</p>

</br>

 

<p>

    <b>常用 gridPanel(适用于查询列表)</b>

<p></p>

    <div id="gridPanel"></div>

</p>

 

 

</body>

</html>

 

--- 控制层(Control)

 

@Controller

@RequestMapping("/springmvctest")

public class EmpController {

 

/**

* 注入 empServices

*/

@Autowired

private IEmpServices empServices;

 

@RequestMapping("/index")

public ModelAndView addEmp(){

ModelAndView view = new ModelAndView();

view.setViewName("springmvctest/index");

//异常测试

//String str=null;

//try{

//str.toString();

//}catch(Exception e){

//throw new TypeMismatchAccessException(e);

//}

return view;

}

 

@RequestMapping(value ="/empAdd",method = RequestMethod.POST)//,produces = "application/json"

@ResponseBody

public Object insertEmp(@RequestBody EmpVo empVo){

Map<String, String> map = new HashMap<String, String>(); 

Random rand = new Random();

empVo.setEmp_id(rand.nextInt(100000));

int i = empServices.addEmp(empVo);

if(i > 0){

map.put("success", "true"); 

map.put("msg", "新增成功!");

}else{

map.put("success", "false"); 

map.put("msg", "新增失败!");

}

 

JSONObject obj =  (JSONObject) JSONObject.toJSON(map);

return obj;

}

 

@RequestMapping(value ="/updateEmp",method = RequestMethod.POST)//,produces = "application/json"

@ResponseBody

public Object updateEmp(@RequestBody EmpVo empVo){

Map<String, String> map = new HashMap<String, String>(); 

int i = empServices.updateEmp(empVo);

if(i > 0){

map.put("success", "true"); 

map.put("msg", "修改成功!");

}else{

map.put("success", "false"); 

map.put("msg", "修改失败!");

}

 

JSONObject obj =  (JSONObject) JSONObject.toJSON(map);

return obj;

}

 

@RequestMapping(value ="/deleteEmp")//,produces = "application/json"

@ResponseBody

public Object deleteEmp(@RequestParam String id){

Map<String, String> map = new HashMap<String, String>(); 

int i = empServices.deleteEmpById(id);

if(i > 0){

map.put("success", "true"); 

map.put("msg", "删除成功!");

}else{

map.put("success", "false"); 

map.put("msg", "删除失败!");

}

 

JSONObject obj =  (JSONObject) JSONObject.toJSON(map);

return obj;

}

 

@RequestMapping("/empList")

@ResponseBody

public  PaginationDto empList(@RequestParam(required = false) String seachKey,@RequestParam int start,@RequestParam int limit){

EmpVo emp = new EmpVo();

emp.setSelectorParam(seachKey);

//try {

//emp.setSelectorParam(new String(seachKey.getBytes("ISO8859-1"),"UTF-8").toString());

//} catch (UnsupportedEncodingException e) {

//// TODO Auto-generated catch block

//e.printStackTrace();

//}

PaginationDto pt = empServices.queryEmpList(emp, start, limit);

return pt;

}

 

}

 

-- 对于 在 如下连接文章中说明了 springMVC的配置

http://wangmengbk.iteye.com/blog/2176076

--- ibatis 配置文件 springmvctest-mapper.xml 内容:

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE mapper PUBLIC 

"-//mybatis.org//DTD Mapper 3.0//EN" 

"http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="dpap.springmvctest.emp" >

<resultMap id="empResultMap"

type="com.deppon.dpap.module.springmvctest.shared.vo.EmpVo">

<id column="EMP_ID" property="emp_id" jdbcType="INTEGER" />

<result column="NAME" property="name"

jdbcType="VARCHAR" />

<result column="AGE" property="age" jdbcType="INTEGER" />

</resultMap>

 

<sql id="emp_Column_List">

EMP_ID, NAME, AGE

</sql>

 

<!-- 插入员工信息 -->

<insert id="addEmp"

parameterType="com.deppon.dpap.module.springmvctest.shared.vo.EmpVo">

<![CDATA[

INSERT INTO EMP_HZG (

]]>

<include refid="emp_Column_List" />

<![CDATA[

)VALUES(

#{emp_id, jdbcType=INTEGER},

#{name, jdbcType=VARCHAR},

#{age, jdbcType=INTEGER}

)

]]>

</insert>

 

<!-- 更新员工信息 -->

<update id="updateEmp"

parameterType="com.deppon.dpap.module.springmvctest.shared.vo.EmpVo">

UPDATE EMP_HZG

<set>

<if test="name != null and name != ''">

NAME = #{name, jdbcType=VARCHAR},

</if>

<if test="age != 0">

AGE = #{age, jdbcType=INTEGER},

</if>

</set>

<where>

<if test="emp_id !=null and emp_id != ''">

EMP_ID = #{emp_id, jdbcType=INTEGER}

</if>

</where>

</update>

 

<!-- 删除员工 -->

<delete id="deleteEmpById">

DELETE FROM EMP_HZG

<where>

EMP_ID = #{emp_id, jdbcType=INTEGER}

</where>

</delete>

 

<!-- 查询员工数量 -->

<select id="queryEmpCount" resultType="java.lang.Long"

parameterType="map">

<![CDATA[ 

SELECT COUNT(*)

FROM EMP_HZG

]]>

<where>

<if test="selectorParam != null and selectorParam != ''">

AND NAME LIKE CONCAT(CONCAT('%', #{selectorParam,

jdbcType=VARCHAR}), '%')

</if>

</where>

</select>

 

<!-- 查询员工集合 -->

<select id="queryEmpList" resultMap="empResultMap"

parameterType="com.deppon.dpap.module.springmvctest.shared.vo.EmpVo">

<![CDATA[ 

SELECT 

]]>

<include refid="emp_Column_List" />

<![CDATA[ 

FROM EMP_HZG

]]>

<where>

<if test="selectorParam != null and selectorParam != ''">

AND NAME LIKE CONCAT(CONCAT('%', #{selectorParam,

jdbcType=VARCHAR}), '%')

</if>

</where>

</select>

 

</mapper>

 

以上对于 PaginationDto 对象就是 一个分页对象其属性也比较简单:

 protected List paginationDtos = new ArrayList();

  protected Long totalCount = 0l;

//TODO:省略 get/set

 

整体效果如下图:
ExtJs+SpringMVC+ibatis 实现_第1张图片
 

你可能感兴趣的:(springMVC)