- 浏览: 93297 次
- 性别:
- 来自: 湖南
文章分类
最新评论
用ext2.0实现一个用户的增,删,改,查
1.在上一节中我们介绍了一些ext的基本用法,现在我们用ext来实现对一个用户的增删改查操作
可参考的代码如下:
jsp代码如下:
java代码如下: 出现的问题: 在实现这个效果的时候,虽然页面上没有报错,但是在页面上总是不能显示那个装载查询出来的数据 的GridPanel,后来经过仔细研究,原来是 <div id="win"><div id="userGrid" style="height: 300px;"></div></div> 这段代码中div的height没有设置。ext2.0就有这么一个缺陷。如果你不设置它的高度,它是显示不出来的。 <%@ page language="java" contentType="text/html; charset=UTF-8" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme() + "://"
+ request.getServerName() + ":" + request.getServerPort()
+ path + "/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>My JSP 'userList.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<link rel="stylesheet" type="text/css" href="extJS/resources/css/ext-all.css">
<script type="text/javascript" src="extJS/js/ext-base.js"></script>
<script type="text/javascript" src="extJS/js/ext-all.js"></script>
<link rel="stylesheet" type="text/css" href="extJS/resources/css/xtheme-purple.css">
</head>
<body>
<div id="win">
<div id="userGrid" style="height: 300px;"></div>
</div>
<div id="formWin">
<div id="form" align="center"></div>
</div>
<script type="text/javascript">
//用户列表
var renderSex=function(value){
if(value=='1'){
return "男";
}else if(value=='2'){
return "女";
}else{
return "保密";
}
};
//构造列表节面的Grid
var sm = new Ext.grid.CheckboxSelectionModel();
var cm = new Ext.grid.ColumnModel([
sm,
new Ext.grid.RowNumberer(),
{header:'编号', dataIndex:'id', sortable:true},
{header:'姓名', dataIndex:'name'},
{header:'年龄', dataIndex:'age'},
{header:'性别', dataIndex:'sex', renderer:renderSex},
{header:'描述', dataIndex:'descn'}
]
);
var ds = new Ext.data.Store({
proxy:new Ext.data.HttpProxy({url:'userAction!list.action'}),
reader:new Ext.data.JsonReader({
totalProperty:'totalProperty',
root:'root',
fields:[
{name:'id', mapping:'id', type:'string'},
{name:'name', mapping:'name', type:'string'},
{name:'age', mapping:'age', type:'int'},
{name:'sex', mapping:'sex', type:'string'},
{name:'descn', mapping:'descn', type:'string'}
]
})
});
var grid=new Ext.grid.GridPanel({
el:'userGrid',
store:ds,
cm:cm,
sm:sm,
bbar:new Ext.PagingToolbar({
pageSize:10,
store:ds,
displayInfo:true,
displayMsg:"显示第{0}条记录到第{1}条记录,共显示{2}条记录",
emptyMsg:"没有记录"
})
});
grid.render();
ds.load({params:{start:0,limit:10}});
//用户新增
function save(){
var form = createForm();
var formWin = createFormWin("用户新增", "新增", "userAction!add.action", form);
formWin.show();
}
//构造下拉列表
function createCombo(){
var sexData=[[1, '男'],[2, '女'], [3, '保密']];
var sexDs = new Ext.data.Store({
proxy: new Ext.data.MemoryProxy(sexData),
reader: new Ext.data.ArrayReader({}, [
{name: 'id' },
{name: 'sex'}
])
});
sexDs.load();
var sexCmb = new Ext.form.ComboBox({
emptyText:'请选择性别',
fieldLabel:'性别',
store:sexDs,
hiddenName:'user.sex',
triggerAction:'all',
displayField:'sex',
mode:'local',
editable:false,
allowBlank:false,
valueField:'id',
width:210
});
return sexCmb;
}
//构造表单
function createForm(){
var sexCmb = createCombo();
var form = new Ext.form.FormPanel({
labelAlign:'center',
labelWidth:50,
title:'Form',
frame:true,
width:220,
closeAction:'hide',
shadow:true,
items:[{xtype:'hidden', name:'user.id'},{fieldLabel:'姓名', name:'user.name',xtype:'textfield'},
{fieldLabel:'年龄', name:'user.age',xtype:'textfield'},
sexCmb,
{fieldLabel:'描述', name:'user.descn',xtype:'textarea'}
]
});
return form;
}
//构造表单窗体
function createFormWin(title, btnText, url, form){
var fwDiv = Ext.get('formWin');
var formWid = new Ext.Window({
el:fwDiv,
layout:'fit',
title:title,
width:500,
height:300,
items:[form],
buttons:[{text:btnText, handler:function(){
form.getForm().submit({
url:url,
method:"POST",
success:function(form, action){
formWid.close();
ds.reload();
},
failure:function(form, action){
Ext.Msg.alert("错误",action.result.errorMsg);
}
});
}}]
});
return formWid;
}
//判读是否选择一条记录
function checkSingleSelect(){
if(grid.selModel.hasSelection()){
var records = grid.selModel.getSelections();
var recordsLen = records.length;
if(recordsLen>1){
Ext.Msg.alert("提示", "只能选择一条记录");
return false;
}else{
return true;
}
}else{
Ext.Msg.alert("提示", "请先选择一条记录");
return false;
}
}
function load(){
}
//用户修改
function edit(){
if(checkSingleSelect()){
var form = createForm();
var records = grid.getSelectionModel().getSelected();
var formWin = createFormWin("用户更新", "修改","userAction!edit.action", form);
formWin.show();
form.getForm().setValues({
'user.id':records.get("id"),
'user.name':records.get("name"),
'user.age':records.get("age"),
'user.sex':records.get("sex"),
'user.descn':records.get("descn")
});
}
}
//用户删除
function remove(){
if(checkSingleSelect()){
var result = Ext.MessageBox.confirm("提示", "你是否确定删除该记录?", function(btn){
if(btn=='yes'){
var records = grid.getSelectionModel().getSelected();
var myCon = new Ext.data.Connection();
myCon.request({
url:'userAction!delete.action',
params:{'deleteIds':records.get("id")},
method:'POST',
success:function(r, o){
var a =Ext.decode(r.responseText);
if(a.success){
ds.reload();
}else{
Ext.Msg.alert("错误",a.errorMsg);
}
},
failure:function(o, r){
Ext.Msg.alert("错误","删除失败!");
}
});
}
}, grid);
}
}
//构造工具栏
var toolBar = new Ext.Toolbar({
buttons:[{text:'新增用户',
handler:save
},
{text:'修改用户',
handler:edit
},
{text:'删除用户',
handler:remove
}]
});
//构造窗体
var win = new Ext.Window({
el:'win',
title:'用户列表',
layout:'fit',
width:700,
height:600,
items:[grid],
tbar:toolBar
});
win.show();
</script>
</body>
</html>
package com.baoz.extPro.action;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.struts2.ServletActionContext;
import com.baoz.extPro.dao.DAO;
import com.baoz.extPro.dao.DAOImpl;
import com.baoz.extPro.entity.User;
import com.baoz.extPro.utils.ActionUtils;
import com.baoz.extPro.utils.JsonUtils;
import com.opensymphony.oscache.util.StringUtil;
import com.opensymphony.xwork2.ActionSupport;
public class UserAction extends ActionSupport {
private User user;
private String deleteIds;
private String s_name;
private String s_age;
private String link_id;
public String getDeleteIds() {
return deleteIds;
}
public void setDeleteIds(String deleteIds) {
this.deleteIds = deleteIds;
}
public User getUser() {
return user;
}
public void setUser(User user) {
this.user = user;
}
public String list() throws Exception {
DAO dao = new DAOImpl();
StringBuffer hql = new StringBuffer();
hql.append("from User as u where 1=1 ");
System.out.println("s_name="+s_name);
System.out.println("s_age="+s_age);
if(s_name!=null && !s_name.equals("")){
hql.append(" and u.name like '%");
hql.append(s_name);
hql.append("%'");
}
if(s_age!=null && !s_age.equals("")){
hql.append(" and u.age=");
hql.append(s_age);
}
List list = dao.someList(hql.toString());
HttpServletRequest request = ServletActionContext.getRequest();
String start = request.getParameter("start");
String limit = request.getParameter("limit");
System.out.println("limit="+limit);
Integer index = Integer.parseInt(start);
Integer pageSize = Integer.parseInt(limit);
System.out.println("index="+start);
System.out.println("pageSize="+limit);
StringBuffer json = new StringBuffer();
json.append("{");
json.append("totalProperty:").append(list.size()).append(", ");
json.append("root:[");
int size = list.size();
if (pageSize + index <= size) {
size = pageSize + index;
}
for (int i = index; i < size; i++) {
User user = (User) list.get(i);
json.append("{id:'").append(user.getId()).append("', name:'")
.append(user.getName()).append("', age:").append(
user.getAge()).append(", sex:'").append(
user.getSex()).append("', descn:'").append(
user.getDescn()).append("'");
if (i == size - 1) {
json.append("}");
} else {
json.append("},");
}
}
json.append("]");
json.append("}");
HttpServletResponse response = ServletActionContext.getResponse();
ActionUtils.sendText(response, json.toString());
return null;
}
public String tree() throws Exception {
StringBuffer json = new StringBuffer();
json.append("[").append(JsonUtils.json.toString()).append("]");
HttpServletResponse response = ServletActionContext.getResponse();
ActionUtils.sendText(response, json.toString());
return null;
}
public String add() {
System.out.println("user=" + user);
DAO dao = new DAOImpl();
HttpServletResponse response = ServletActionContext.getResponse();
try {
dao.save(user);
ActionUtils.sendText(response, "{success:true}");
} catch (Exception e) {
e.printStackTrace();
ActionUtils.sendText(response, "{success:false, errorMsg:'添加"
+ user.getName() + "失败!'}");
}
return null;
}
public String edit() {
DAO dao = new DAOImpl();
HttpServletResponse response = ServletActionContext.getResponse();
try {
dao.update(user);
ActionUtils.sendText(response, "{success:true}");
} catch (Exception e) {
e.printStackTrace();
ActionUtils.sendText(response, "{success:false, errorMsg:'修改"
+ user.getName() + "失败!'}");
}
return null;
}
public String delete() {
DAO dao = new DAOImpl();
HttpServletResponse response = ServletActionContext.getResponse();
try {
String[] idArray = deleteIds.split(",");
for (String id : idArray) {
dao.delete(User.class, id);
}
ActionUtils.sendText(response, "{success:true}");
} catch (Exception e) {
e.printStackTrace();
ActionUtils.sendText(response, "{success:false, errorMsg:'删除失败!'}");
}
return null;
}
public String link(){
System.out.println("link_id="+link_id);
return null;
}
public String getS_age() {
return s_age;
}
public void setS_age(String s_age) {
this.s_age = s_age;
}
public String getS_name() {
return s_name;
}
public void setS_name(String s_name) {
this.s_name = s_name;
}
public String getLink_id() {
return link_id;
}
public void setLink_id(String link_id) {
this.link_id = link_id;
}
}
相关推荐
### Ext2.0学习笔记:深入理解Ajax与Ext框架 #### Ajax:实现异步无刷新数据交换的关键技术 Ajax(Asynchronous JavaScript and XML)是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。它利用了...
Ext2.0是Ext JS的一个早期版本,是一个强大的JavaScript库,用于构建富客户端Web应用程序。...通过深入学习和实践这些教程,你可以熟练地运用Ext2.0和JavaFX来构建功能丰富、用户体验优秀的Web和桌面应用程序。
目录 1. ExtJs 结构树 2 2. 对ExtJs的态度 3 3. Ext.form概述 4 4. Ext.TabPanel篇 5 5. Function扩展篇 7 6. Ext.data.Store篇 10 7. Ext.data.JsonReader篇一 12 ...28. extJs 2.0学习笔记(ext.js篇) 77
- **ExtJs2.0学习笔记(Ext.data序论篇)**:这部分内容是对Ext JS 2.0中`Ext.data`模块的概述,讲解了如何管理和操作数据。 - **ExtJs2.0学习笔记(Ext.Panel终结篇)**:深入探讨了`Ext.Panel`组件的各种特性和用法。...
14. **extJs 2.0 学习笔记(Ext.data序论篇)** 这部分介绍了Ext.data模块的基础,包括DataModel、Reader和Writer,是理解数据绑定和数据管理的关键。 15. **extJs 2.0 学习笔记(Ext.Panel终结篇)** Panel是...
在"ExtJS2.0开发与实践笔记"系列文档中,你将了解到EXTJS2.0版本的基础知识,包括如何创建基本组件,设置布局,处理事件,以及如何利用EXTJS提供的API进行交互设计。这些笔记将帮助初学者快速入门EXTJS的开发。 ...
13. **extJs 2.0 学习笔记**:这部分内容专注于ExtJs 2.0版本,可能包括新特性、改进和兼容性问题。 通过这些笔记,读者可以逐步掌握ExtJs的基本用法,从构建简单的UI组件到处理复杂的异步数据交互,为开发高质量的...
5. **EXT2.0组件体系**:EXT2.0引入了清晰的组件层次结构,组件由`Component`类定义,每个组件有一个特定的`xtype`属性,用于标识组件类型。组件分为基本组件、工具栏组件和表单及元素组件三类,涵盖了大量的常用UI...
EXTJS in Action 是一本专为学习EXTJS编写的书籍,但这里我们主要关注学习笔记中的关键知识点。 首先,EXTJS的目录结构非常重要,因为它包含了所有必要的资源和源码: 1. `adapter`:这部分包含了适配器,用于将...
### ExtJS面板学习笔记 #### 一、基础:弹出框 在ExtJS中,`Ext.MessageBox`提供了创建各种模态对话框的功能,包括提示、确认、输入等。以下是几个基本示例: 1. **简单警告对话框**: ```javascript Ext....
《EXT学习笔记.doc》可能是个人或团队在学习EXTJS过程中整理的笔记,包含了他们的实践经验、技巧和问题解决方案,对于学习EXTJS非常有帮助。 《EXT核心API详解.pdf》是对EXTJS核心API的深入解析,适合想要深入研究...
4. **Ext2**:主要用于Linux系统,提供更好的性能和可靠性。 分区软件有多种,如Fdisk、Partition Magic(分区大师)和F32,它们可以帮助用户轻松创建、调整和格式化分区。 总之,了解和掌握BIOS设置及硬盘分区是...
7.5.2 **分区格式**:常见的分区格式有FAT16、FAT32、NTFS和Ext2。FAT16是较老的格式,支持的最大分区大小有限。FAT32是后来的改进版,支持更大的分区,广泛应用于多种操作系统。NTFS是Windows NT系列操作系统的默认...