- 浏览: 83943 次
- 性别:
- 来自: 西安
最新评论
-
xieweiting:
把response返回属性改下, response.setCo ...
http://huoyunshen888.iteye.com/admin/blogs/new
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>
<title>extJs中常用到的增删改查操作的示例代码</title>
<!-- CommonJs.jsp 为 ExtJS 引入的路径 -->
<%@ include file="../extJs/CommonJs.jsp"%>
<script type="text/javascript"><!--
/**
* 作 者: 花 慧
* 时 间: 2009年12月22日
* 内 容: extJs中常用到的增,删,改,查操作
*/
//设置每页显示的行数默认为10
var QUERY_PAGE_SIZE = 10;
/**
* SearchQueryForm():绘制查询表单
*/
function searchQueryForm()
{
//form 使用的时候建议设为局部变量,可以通过Ext.getCmp(“”)去获取form
var queryForm = null;
queryForm = new Ext.FormPanel({
id:'queryForm', //指定queryForm的Id
renderTo:'searchPanel', //指向form所在的div层
labelWidth:70, //label标签的width占页面的百分比
region:'north',
border:false, //以显示面板的body元素的边界,虚假隐藏起来(默认为true)
badyBorder:false, //显示面板的body元素,假以隐藏它(默认为true的内部边界)
labelAlign:'right', //label标签的对齐方式
frame:true, //自定义面板的圆形边界,边界宽度1px。默认为false
title:'用户信息查询', //form的标题
/**
*buttons:在FormPanel中按钮的集合
*/
buttons:[{handler:addForm,text:'新增'},
{handler:submitForm,text:'查询'},
{handler:resetForm,text:'重置'}],
/**
* items: 在FormPanel中不可缺少的部分
*/
items:[{
/**
* layout:extJs容器组件,可以设置它的显示风格
* 它的有效值有absolute,accordion,anchor,border,card,fit,form and table 共9种
*/
layout:'column',
items:[
{
columnWidth:.5,
layout:'form',
items:{
name:'userId',
hiddenName:'userId',
xtype:'textfield',
fieldLabel:'用户编码',
maxLength:'50',
vtype:'specialChar',
anchor:'80%'
}
},{
columnWidth:.5,
layout:'form',
items:{
name:'userName',
hiddenName:'userName',
xtype:'textfield',
fieldLabel:'用户名称',
maxLength:'100',
vtype:'specialChar',
anchor:'80%'
}
}
]
}]
});
}
/**
* showUserForm():绘制添加表单
*/
function showUserForm()
{
//将变量定义成局部变量,避免每次都生成一个新对象
var userForm = null;
userForm = new Ext.FormPanel({
id:'conditionForm',
labelWidth:'80',
labelAlign:'right',
border:false,
bodyBorder:false,
frame:true,
items:[
layout:'column',
items:[
{
columnWidth:'.8',
items:{
name:'userInfo.userId',
hiddenName:'userInfo.userId', //hiddenName动态的绑定数据库中对应的字段
xtype:'textField', //xtype可以分为三类,textField为表单域的控件
fieldLabel:'用户编码<font color=red>*</font>',//控件前的文本说明
labelSeparator:'',
blankText : '填写用户编码', //为空的文本框提示信息
allowBlank:false, //不允许为空
maxLength:'50', //文本框允许输入的最大的长度,最小的minLength
vtype:'specialChar',
anchor:'80%'
}
},{
columnWidth:'.8',
items:{
name:'userInfo.userName',
hiddenName:'userInfo.userName',
xtype:'textField',
fieldLabel:'用户姓名<font color=red>*</font>',
labelSeparator:'',
blankText:'填写用户姓名',
allowBlank:false,
maxLength:'100',
vtype:'specialChar',
anchor:'100%'
}
},{
columnWidth:'.8',
items:{
name:'userInfo.pwd',
hiddenName:'userInfo.pwd',
xtype:'textField',
inputType:'password',
fieldLabel:'用户密码<font color=red>*</font>',
labelSeparator:'',
blankText:'填写用户密码',
allowBlank:false,
maxLength:'12',
minLength:'6',
value:'123456', //用户默认的秘密
anchor:'100%'
}
},{
columnWidth:'.8',
items:{
name:'rPwd',
hiddenName:'rPwd',
xtype:'textField',
inputType:'password',
fieldLabel:'确认密码<font color=red>*</font>',
labelSeparator:'',
blankText:'二次输入的秘密要相同',
allowBlank:false,
vtype:'pwdRange',
pwdRange:{begin:'userInfo.pwd',end:'rPwd'},
maxLength:'12',
anchor:'100%'
}
}]
]
});
}
/**
* editUserForm():绘制修改表单
*/
function editUserForm(){
//将变量定义成局部变量,避免每次都生成一个新对象
var userForm = null;
userForm = new Ext.FormPanel({
id:'editForm',
labelWidth:'80',
labelAlign:'right',
border:false,
bodyBorder:false,
frame:true,
items:[
layout:'column',
items:[
{
columnWidth:'.8',
items:{
name:'userInfo.userId',
hiddenName:'userInfo.userId', //hiddenName动态的绑定数据库中对应的字段
xtype:'textField', //xtype可以分为三类,textField为表单域的控件
fieldLabel:'用户编码', //控件前的文本说明
labelSeparator:':',
readOnly:true, //文本框只读
disabled:true, //文本框灰色,区别与其他的文本框颜色
blankText : '填写用户编码', //为空的文本框提示信息
allowBlank:false, //不允许为空
maxLength:'50', //文本框允许输入的最大的长度,最小的minLength
//字母开头,且只能存在字母与数字长度为2到12位
regex : /^[a-zA-Z]{1}([a-zA-Z0-9]|[_]){1,11}$/,
regexText : '用户编码必须以字母开头,长度2-12位!',
anchor:'90%'
}
},{
columnWidth:'.8',
items:{
name:'userInfo.userName',
hiddenName:'userInfo.userName',
xtype:'textField',
fieldLabel:'用户姓名',
labelSeparator:':',
blankText:'填写用户姓名',
allowBlank:false,
maxLength:'100',
//只含有汉字、数字、字母、下划线不能以下划线开头和结尾
regex : /^(?!_)(?!.*?_$)[a-zA-Z0-9_\u4e00-\u9fa5]+$/,
regexText : '只含有汉字、数字、字母、下划线不能以下划线开头和结尾!',
anchor:'90%'
}
},{
columnWidth:'.2',
items:{
hiddenName:"infoFill",
name:"infoFill",
xtype:'label',
html:'<font color=red>*</font>',
labelSeparator:'',
anchor:'100%'
}
},{
columnWidth:'.8',
items:{
name:'userInfo.pwd',
hiddenName:'userInfo.pwd',
xtype:'textField',
inputType:'password',
fieldLabel:'用户密码<font color=red>*</font>',
labelSeparator:':',
blankText:'填写用户密码',
allowBlank:false,
maxLength:'12',
minLength:'6',
anchor:'90%'
}
},{
columnWidth:'.2',
items:{
hiddenName:"infoFill",
name:"infoFill",
xtype:'label',
html:'<font color=red>*</font>',
labelSeparator:'',
anchor:'100%'
}
},{
columnWidth:'.8',
items:{
name:'rPwd',
hiddenName:'rPwd',
xtype:'textField',
inputType:'password',
fieldLabel:'确认密码<font color=red>*</font>',
labelSeparator:':',
blankText:'二次输入的秘密要相同',
allowBlank:false,
//在extCommon.js文件中定义二次输入的密码相同验证pwdRange
// vtype为验证的方法,如果是通用的验证,请在方法中定义,如果是特例,可以使用regex
vtype:'pwdRange',
pwdRange:{begin:'userInfo.pwd',end:'rPwd'},
maxLength:'12',
anchor:'90%'
}
},{
columnWidth:'.2',
items:{
hiddenName:"infoFill",
name:"infoFill",
xtype:'label',
html:'<font color=red>*</font>',
labelSeparator:'',
anchor:'100%'
}
}]
]
});
}
/**
* onReady:该文件准备好(在onload和图像加载之前)
*/
Ext.onReady(function(){
searchQueryForm();
//获取查询form
var queryForm = Ext.getCmp("queryForm").getForm();
/**
* layout设置为border表示页面将划分为东南西北中五个部分
* 这里表示centerPanel放在中间
*/
var layout = new Ext.Viewport({
layout:'border',
defaluts:{border:false,bodyBorder:false,activeTab:0},
items:[queryForm,{id:'centerPanel',region:'center',height:document.body.clientHeight,contentEl:'mainDiv'}]
});
//页面加载的时候,默认数据查询页面显示用户信息列表
submitForm();
});
//查询信息
var store = new Ext.data.Store({
url:'../user/doGetPageList.action', //action的路径
reader:new Ext.data.JsonReader({
root:'userList', //从struts2.0里面传递过来的参数:用户的集合
totalProperty:'rowTotal', //从struts2.0里面传递过来的参数:总共的信息的行数
id:'userId',
successPropery:'success'},
['userId','userName','pwd']
)
});
/**
* callback:调用的函数
*/
function getMsg()
{
}
/**
* 模糊查询
*/
function submitForm()
{
//初始化grid
var grid = null;
//复选框
var sm = new Ext.grid.CheckboxSelectionModel({
dataIndex:'id',
width:'20'
});
/**
* sortabel:(可选)如果真要排序允许在此列
* renderer:(可选)用于生成给定数据值单元格的HTML标记的功能。如果没有指定,默认渲染器使用的原始数据值。
* 在renderer:function createButton(参数)这里的参数可以没有或多个
* 鼠标移动图片上变成"手"是:style="cursor:hand"
*/
var colM = new Ext.grid.ColumnModel(
[sm,{header:'用户账号',dataIndex:'userId',align:'center',sortable:true},
{header:'用户姓名',dataIndex:'userName',align:'center',sortabel:true},
{header:'删除',dataIndex:'id',align:'center',renderer:function createButton(){
return '<img alt="删除" style="cursor:hand" style="cursor:hand" src="../images/hh_framework/ico_delete.gif" src="images/hh_framework/ico_delete.gif" />';}},
{header:'编辑',dataIndex:'userId',align:'center',renderer:function createButton(userId, metadata, record){
return '<a style="cursor:hand" style="cursor:hand" onclick=updateForm('+userId+') >'+record.get('userName')+'的信息修改'+'</a>';}}]
);
//获取查询表单
var form = Ext.getCmp("queryForm").getForm();
//判断是否通过验证,如果没有请直接关闭
if(!form.isValid())
{
Ext.Msg.alert("系统提示","查询数据不正确,请确认输入!");
return ;
}
//差选queryform中查询的数据参数
store.baseParams = form.getValues();
/**
* getLimitCount():获取分页每页行数,如果不传值,则会取默认值
* Start表示读取数据的起始位置、limit表示每次读取多少条数据
* callback:getMsg 表示回调时,执行函数 getMsg。可省略
*/
store.load({params:{start:0,limit:getLimitCount()}, callback:getMsg});
if(grid == null)
{
grid = new Ext.grid.EditorGridPanel({
renderTo:"mainDiv", //grid查询结果指向显示的div层
title:"用户查询结果", //grid标题
width:document.body.clientWidth, //设置grid的width的值
hight:document.doby.clientHight-100,//设置hight的值
viewConfig:{forceFit:true}, //设置列数的充满窗口
loadMask:true, //在加载数据时的遮罩效果
stripeRows:true, //隔行换色
region:'center', //这个是设置在ViewPort中显示的位置
cm:colM, //定义的列
ds:store, //定义的数据源
border:false,
bodyBorder:false,
sm:sm, //定义的复选框
//listeners:包含一个或多个事件处理程序被添加到这个对象初始化过程中
listeners:{cellclick:renderPage},
/**
* bbar: new Ext.PagingToolbar部分是定义分页工具栏,
* 这里的分页控件栏还用到了1个自己定义的插件,就是可以选择每页显示多少条的
* plugins : [new Ext.ux.PageSizePlugin()],参考Ext的API
* 要实现分页,后台必须有total属性,表示共多少条数据
*/
bbar:new Ext.PagingToolbar({
items:[{
xtype:'button',
text:'删除所选',
handler:delUserAll, //自定义执行动
pressed:true
}],
id:'pageToolBar',
pageSize:QUERY_PAGE_SIZE, //每页的行数默认为:QUERY_PAGE_SIZE
store:store,
displayInfo:true,
displayMsg:'显示第{0}条到{1}条记录,共{2}条记录',
emptMsg:'没有记录',
plugins:[new Ext.ux.PageSizePlugin()]
})
});
}
grid.render();
}
/**
* 增加用户信息
*/
function addForm()
{
showUserForm();
//获取绘制用户窗口的form
var userForm = Ext.getCmp("conditionForm").getForm();
//初始化用户添加的窗口的Id
var addUserWin = Ext.getCmp("addWin");
if(addUserWin == null)
{
addUserWin = new Ext.Window({
width:500, //初始窗口的width的值
x:100, //窗口的初始化x方向的位置
y:100, //窗口的初始化y方向的位置
plain:true,
modal:true, //模式窗口,默认为false
closeAction:"hide", //默认窗口隐藏
resizable:false, //窗口的大小不允许拖动,默认为true
id:"addWin", //指定用户添加窗口的Id
items:[userForm],
buttons:[
{text:'保存',handler:function(){
if(userForm.form.isValid()){
userForm.form.doAction('submit',{
url:'../user/addUser.action',
params:{roleId:userForm.form.findField('userId').getValue()},
method:'post', //数据提交的方式:有两种get,post
waitTitle:'提示信息', //数据提交等待的滚动条
waitMsg:'保存数据,请稍候...', //滚动条提示的内容
success:function(form,action){
var message = action.result.message;
if(message == null){
Ext.Msg.alert("提示信息","用户信息添加成功!");
store.reload();
addUserWin.hide();
}else{
Ext.Msg.alert("提示信息",message);
}
},
failure:function(form,action){
Ext.Msg.alert('提示信息',"新用户添加失败!");
return;
}
});
}else {
Ext.Msg.alert("提示信息","表单有错误,请正确填写!");
}
}},
{handler:function(){userForm.form.reset();},text:'重置'},
{handler:function(){addUserWin.hide();},text:'关闭'}]
});
}
addUserWin.show();
}
/**
* 删除用户信息
*/
function delForm(userId)
{
Ext.Msg.confirm('提示信息','你确定要执行删除操作吗?',function(btn){
if(btn == 'yes')
{
/**
* 数据提交的一种方式:Ext.Ajax.request({});
*/
Ext.Ajax.request({
url:'../user/delUser.action',
params:{userId:userId},
method:'post',
success:function(o)
{
var info = Ext.decode(o.responseText);
Ext.Msg.alert("提示信息",info.message);
store.reload();
return ;
},
failure:function(form,action)
{
Ext.Msg.alert("提示信息","用户信息删除失败!");
return ;
}
});
}
});
}
/**
* 批量删除事件
*/
function delUserAll()
{
//grid中复选框被选中的项
var rows = grid.getSelectionModel().getSelections();
//user_id:所有选中的用户Id的集合使用','隔开,初始化为空
var user_id = '';
for(var i = 0;i<rows.length;i++)
{
if(i>0)
{
user_id = user_id+','+rows[i].get('userId');
}else{
user_id = user_id+rows[i].get('userId');
}
}
//没有选择要执行操作的对象
if(user_id == "")
{
Ext.Msg.alert("提示信息","请选择要删除的对象");
return ;
}else{
Ext.Msg.confirm("提示信息","请确定要执行删除操作吗?",function (btn){
if(btn == 'yes')
{
Ext.Ajax.request({
url:"../user/delAllUser.action",
params:{id:user_id},
method:'post',
success:function(o){
var info = Ext.decode(o.responseText);
Ext.Msg.alert("提示信息",info.message);
store.reload();
return ;
},
failure:function(form,action){
Ext.Msg.alert("提示信息","用户信息删除失败!");
}
});
}
});
}
}
/**
* 修改用户信息
* 参数userId:修改对象的Id
*/
function updateForm(userId)
{
editUserForm();
var userForm = Ext.getCmp("editForm").getForm();
Ext.Ajax.request({
url:'../user/doGetOne.action',
params:{userId:userId},
method:'post',
//从struts2.0里返回的参数
success:function(o)
{
//读取action传递过来的对象参数
//docode:解码(解析)一个JSON字符串对象
var user = Ext.decode(o.responseText);
//用户编辑窗口的打开
editUser(user);
//将对象信息显示在对应的form文本框中
userForm.form.findFiled('userInfo.userId').setValue(user.userInfo.userId);
userForm.form.findFiled('userInfo.userName').setValue(user.userInfo.userName);
userForm.form.findFiled('userInfo.pwd').setValue(user.userInfo.pwd);
userForm.form.findFiled('rPwd').setValue(user.userInfo.pwd);
}
});
}
/**
* 用户信息编辑窗口
*/
function editUser(user){
var userForm = Ext.getCmp("editForm").getForm();
//得到用户编辑的窗口的对象
var editUserWin = Ext.getCmp("editWin");
//当为空的时候将进行实例化
if(editUserWin == null)
{
editUserWin = new Ext.Window({
id:'editWin',
width:500,
x:100,
y:100,
modal:true,
resizable:false,
closeAction:"hide",
title:'用户信息修改',
items:[userForm],
buttons:[
{text:'保存',handler:function(){
if(userForm.form.isValid())
{
/**
* 数据提交的第二种方式:form.doAction('submit',{});
*/
userForm.form.doAction('submit',{
url:'../user/updUser.action',
params:{userId:userForm.form.findField('userInfo.userId').getValue()},
method:'post',
waitTitle:'提示信息',
waitMsg:'数据处理中,请稍后....',
//从struts2.0里不需要返回的参数
success:function(form,action)
{
Ext.Msg.alert("提示信息","用户信息修改成功!");
//查询的数据集合store刷新,实现页面自动刷新的效果
store.reload();
//将窗口关闭时候,window. hide()方法是隐藏,因此并不会真正销毁窗口对象
editUserWin.hide();
return ;
},
failure:function(form,action)
{
Ext.Msg.alert("提示信息","用户信息修改失败");
return ;
}
});
}else
{
Ext.Msg.alert("提示信息","表单有错误,请重新填写!");
}
}},
{text:'关闭',handler:function(){editUserWin.hide();}}]
});
}
editUserWin.show();
}
/**
* 重置页面查询表单
*/
function resetForm()
{
Ext.getCmp("queryForm").getForm().reset();
}
/**
* 每行单元格点击事件
*/
function renderPage(grid,rowIndex,columnIndex,e)
{
//触发事件的对象的Id
var id = grid.getStore().getAt(rowIndex).data['userId'];
switch(columuIndex)
{
case 3:delForm(id);
break;
/**
*case 4:updateForm(id);
* break;
*/
default:break;
}
}
// --></script>
</head>
<body>
<div id="searchPanel">
</div>
<div id="centerPanel">
</div>
<div id="mainDiv"></div>
</body>
</html>
<html>
<head>
<title>extJs中常用到的增删改查操作的示例代码</title>
<!-- CommonJs.jsp 为 ExtJS 引入的路径 -->
<%@ include file="../extJs/CommonJs.jsp"%>
<script type="text/javascript"><!--
/**
* 作 者: 花 慧
* 时 间: 2009年12月22日
* 内 容: extJs中常用到的增,删,改,查操作
*/
//设置每页显示的行数默认为10
var QUERY_PAGE_SIZE = 10;
/**
* SearchQueryForm():绘制查询表单
*/
function searchQueryForm()
{
//form 使用的时候建议设为局部变量,可以通过Ext.getCmp(“”)去获取form
var queryForm = null;
queryForm = new Ext.FormPanel({
id:'queryForm', //指定queryForm的Id
renderTo:'searchPanel', //指向form所在的div层
labelWidth:70, //label标签的width占页面的百分比
region:'north',
border:false, //以显示面板的body元素的边界,虚假隐藏起来(默认为true)
badyBorder:false, //显示面板的body元素,假以隐藏它(默认为true的内部边界)
labelAlign:'right', //label标签的对齐方式
frame:true, //自定义面板的圆形边界,边界宽度1px。默认为false
title:'用户信息查询', //form的标题
/**
*buttons:在FormPanel中按钮的集合
*/
buttons:[{handler:addForm,text:'新增'},
{handler:submitForm,text:'查询'},
{handler:resetForm,text:'重置'}],
/**
* items: 在FormPanel中不可缺少的部分
*/
items:[{
/**
* layout:extJs容器组件,可以设置它的显示风格
* 它的有效值有absolute,accordion,anchor,border,card,fit,form and table 共9种
*/
layout:'column',
items:[
{
columnWidth:.5,
layout:'form',
items:{
name:'userId',
hiddenName:'userId',
xtype:'textfield',
fieldLabel:'用户编码',
maxLength:'50',
vtype:'specialChar',
anchor:'80%'
}
},{
columnWidth:.5,
layout:'form',
items:{
name:'userName',
hiddenName:'userName',
xtype:'textfield',
fieldLabel:'用户名称',
maxLength:'100',
vtype:'specialChar',
anchor:'80%'
}
}
]
}]
});
}
/**
* showUserForm():绘制添加表单
*/
function showUserForm()
{
//将变量定义成局部变量,避免每次都生成一个新对象
var userForm = null;
userForm = new Ext.FormPanel({
id:'conditionForm',
labelWidth:'80',
labelAlign:'right',
border:false,
bodyBorder:false,
frame:true,
items:[
layout:'column',
items:[
{
columnWidth:'.8',
items:{
name:'userInfo.userId',
hiddenName:'userInfo.userId', //hiddenName动态的绑定数据库中对应的字段
xtype:'textField', //xtype可以分为三类,textField为表单域的控件
fieldLabel:'用户编码<font color=red>*</font>',//控件前的文本说明
labelSeparator:'',
blankText : '填写用户编码', //为空的文本框提示信息
allowBlank:false, //不允许为空
maxLength:'50', //文本框允许输入的最大的长度,最小的minLength
vtype:'specialChar',
anchor:'80%'
}
},{
columnWidth:'.8',
items:{
name:'userInfo.userName',
hiddenName:'userInfo.userName',
xtype:'textField',
fieldLabel:'用户姓名<font color=red>*</font>',
labelSeparator:'',
blankText:'填写用户姓名',
allowBlank:false,
maxLength:'100',
vtype:'specialChar',
anchor:'100%'
}
},{
columnWidth:'.8',
items:{
name:'userInfo.pwd',
hiddenName:'userInfo.pwd',
xtype:'textField',
inputType:'password',
fieldLabel:'用户密码<font color=red>*</font>',
labelSeparator:'',
blankText:'填写用户密码',
allowBlank:false,
maxLength:'12',
minLength:'6',
value:'123456', //用户默认的秘密
anchor:'100%'
}
},{
columnWidth:'.8',
items:{
name:'rPwd',
hiddenName:'rPwd',
xtype:'textField',
inputType:'password',
fieldLabel:'确认密码<font color=red>*</font>',
labelSeparator:'',
blankText:'二次输入的秘密要相同',
allowBlank:false,
vtype:'pwdRange',
pwdRange:{begin:'userInfo.pwd',end:'rPwd'},
maxLength:'12',
anchor:'100%'
}
}]
]
});
}
/**
* editUserForm():绘制修改表单
*/
function editUserForm(){
//将变量定义成局部变量,避免每次都生成一个新对象
var userForm = null;
userForm = new Ext.FormPanel({
id:'editForm',
labelWidth:'80',
labelAlign:'right',
border:false,
bodyBorder:false,
frame:true,
items:[
layout:'column',
items:[
{
columnWidth:'.8',
items:{
name:'userInfo.userId',
hiddenName:'userInfo.userId', //hiddenName动态的绑定数据库中对应的字段
xtype:'textField', //xtype可以分为三类,textField为表单域的控件
fieldLabel:'用户编码', //控件前的文本说明
labelSeparator:':',
readOnly:true, //文本框只读
disabled:true, //文本框灰色,区别与其他的文本框颜色
blankText : '填写用户编码', //为空的文本框提示信息
allowBlank:false, //不允许为空
maxLength:'50', //文本框允许输入的最大的长度,最小的minLength
//字母开头,且只能存在字母与数字长度为2到12位
regex : /^[a-zA-Z]{1}([a-zA-Z0-9]|[_]){1,11}$/,
regexText : '用户编码必须以字母开头,长度2-12位!',
anchor:'90%'
}
},{
columnWidth:'.8',
items:{
name:'userInfo.userName',
hiddenName:'userInfo.userName',
xtype:'textField',
fieldLabel:'用户姓名',
labelSeparator:':',
blankText:'填写用户姓名',
allowBlank:false,
maxLength:'100',
//只含有汉字、数字、字母、下划线不能以下划线开头和结尾
regex : /^(?!_)(?!.*?_$)[a-zA-Z0-9_\u4e00-\u9fa5]+$/,
regexText : '只含有汉字、数字、字母、下划线不能以下划线开头和结尾!',
anchor:'90%'
}
},{
columnWidth:'.2',
items:{
hiddenName:"infoFill",
name:"infoFill",
xtype:'label',
html:'<font color=red>*</font>',
labelSeparator:'',
anchor:'100%'
}
},{
columnWidth:'.8',
items:{
name:'userInfo.pwd',
hiddenName:'userInfo.pwd',
xtype:'textField',
inputType:'password',
fieldLabel:'用户密码<font color=red>*</font>',
labelSeparator:':',
blankText:'填写用户密码',
allowBlank:false,
maxLength:'12',
minLength:'6',
anchor:'90%'
}
},{
columnWidth:'.2',
items:{
hiddenName:"infoFill",
name:"infoFill",
xtype:'label',
html:'<font color=red>*</font>',
labelSeparator:'',
anchor:'100%'
}
},{
columnWidth:'.8',
items:{
name:'rPwd',
hiddenName:'rPwd',
xtype:'textField',
inputType:'password',
fieldLabel:'确认密码<font color=red>*</font>',
labelSeparator:':',
blankText:'二次输入的秘密要相同',
allowBlank:false,
//在extCommon.js文件中定义二次输入的密码相同验证pwdRange
// vtype为验证的方法,如果是通用的验证,请在方法中定义,如果是特例,可以使用regex
vtype:'pwdRange',
pwdRange:{begin:'userInfo.pwd',end:'rPwd'},
maxLength:'12',
anchor:'90%'
}
},{
columnWidth:'.2',
items:{
hiddenName:"infoFill",
name:"infoFill",
xtype:'label',
html:'<font color=red>*</font>',
labelSeparator:'',
anchor:'100%'
}
}]
]
});
}
/**
* onReady:该文件准备好(在onload和图像加载之前)
*/
Ext.onReady(function(){
searchQueryForm();
//获取查询form
var queryForm = Ext.getCmp("queryForm").getForm();
/**
* layout设置为border表示页面将划分为东南西北中五个部分
* 这里表示centerPanel放在中间
*/
var layout = new Ext.Viewport({
layout:'border',
defaluts:{border:false,bodyBorder:false,activeTab:0},
items:[queryForm,{id:'centerPanel',region:'center',height:document.body.clientHeight,contentEl:'mainDiv'}]
});
//页面加载的时候,默认数据查询页面显示用户信息列表
submitForm();
});
//查询信息
var store = new Ext.data.Store({
url:'../user/doGetPageList.action', //action的路径
reader:new Ext.data.JsonReader({
root:'userList', //从struts2.0里面传递过来的参数:用户的集合
totalProperty:'rowTotal', //从struts2.0里面传递过来的参数:总共的信息的行数
id:'userId',
successPropery:'success'},
['userId','userName','pwd']
)
});
/**
* callback:调用的函数
*/
function getMsg()
{
}
/**
* 模糊查询
*/
function submitForm()
{
//初始化grid
var grid = null;
//复选框
var sm = new Ext.grid.CheckboxSelectionModel({
dataIndex:'id',
width:'20'
});
/**
* sortabel:(可选)如果真要排序允许在此列
* renderer:(可选)用于生成给定数据值单元格的HTML标记的功能。如果没有指定,默认渲染器使用的原始数据值。
* 在renderer:function createButton(参数)这里的参数可以没有或多个
* 鼠标移动图片上变成"手"是:style="cursor:hand"
*/
var colM = new Ext.grid.ColumnModel(
[sm,{header:'用户账号',dataIndex:'userId',align:'center',sortable:true},
{header:'用户姓名',dataIndex:'userName',align:'center',sortabel:true},
{header:'删除',dataIndex:'id',align:'center',renderer:function createButton(){
return '<img alt="删除" style="cursor:hand" style="cursor:hand" src="../images/hh_framework/ico_delete.gif" src="images/hh_framework/ico_delete.gif" />';}},
{header:'编辑',dataIndex:'userId',align:'center',renderer:function createButton(userId, metadata, record){
return '<a style="cursor:hand" style="cursor:hand" onclick=updateForm('+userId+') >'+record.get('userName')+'的信息修改'+'</a>';}}]
);
//获取查询表单
var form = Ext.getCmp("queryForm").getForm();
//判断是否通过验证,如果没有请直接关闭
if(!form.isValid())
{
Ext.Msg.alert("系统提示","查询数据不正确,请确认输入!");
return ;
}
//差选queryform中查询的数据参数
store.baseParams = form.getValues();
/**
* getLimitCount():获取分页每页行数,如果不传值,则会取默认值
* Start表示读取数据的起始位置、limit表示每次读取多少条数据
* callback:getMsg 表示回调时,执行函数 getMsg。可省略
*/
store.load({params:{start:0,limit:getLimitCount()}, callback:getMsg});
if(grid == null)
{
grid = new Ext.grid.EditorGridPanel({
renderTo:"mainDiv", //grid查询结果指向显示的div层
title:"用户查询结果", //grid标题
width:document.body.clientWidth, //设置grid的width的值
hight:document.doby.clientHight-100,//设置hight的值
viewConfig:{forceFit:true}, //设置列数的充满窗口
loadMask:true, //在加载数据时的遮罩效果
stripeRows:true, //隔行换色
region:'center', //这个是设置在ViewPort中显示的位置
cm:colM, //定义的列
ds:store, //定义的数据源
border:false,
bodyBorder:false,
sm:sm, //定义的复选框
//listeners:包含一个或多个事件处理程序被添加到这个对象初始化过程中
listeners:{cellclick:renderPage},
/**
* bbar: new Ext.PagingToolbar部分是定义分页工具栏,
* 这里的分页控件栏还用到了1个自己定义的插件,就是可以选择每页显示多少条的
* plugins : [new Ext.ux.PageSizePlugin()],参考Ext的API
* 要实现分页,后台必须有total属性,表示共多少条数据
*/
bbar:new Ext.PagingToolbar({
items:[{
xtype:'button',
text:'删除所选',
handler:delUserAll, //自定义执行动
pressed:true
}],
id:'pageToolBar',
pageSize:QUERY_PAGE_SIZE, //每页的行数默认为:QUERY_PAGE_SIZE
store:store,
displayInfo:true,
displayMsg:'显示第{0}条到{1}条记录,共{2}条记录',
emptMsg:'没有记录',
plugins:[new Ext.ux.PageSizePlugin()]
})
});
}
grid.render();
}
/**
* 增加用户信息
*/
function addForm()
{
showUserForm();
//获取绘制用户窗口的form
var userForm = Ext.getCmp("conditionForm").getForm();
//初始化用户添加的窗口的Id
var addUserWin = Ext.getCmp("addWin");
if(addUserWin == null)
{
addUserWin = new Ext.Window({
width:500, //初始窗口的width的值
x:100, //窗口的初始化x方向的位置
y:100, //窗口的初始化y方向的位置
plain:true,
modal:true, //模式窗口,默认为false
closeAction:"hide", //默认窗口隐藏
resizable:false, //窗口的大小不允许拖动,默认为true
id:"addWin", //指定用户添加窗口的Id
items:[userForm],
buttons:[
{text:'保存',handler:function(){
if(userForm.form.isValid()){
userForm.form.doAction('submit',{
url:'../user/addUser.action',
params:{roleId:userForm.form.findField('userId').getValue()},
method:'post', //数据提交的方式:有两种get,post
waitTitle:'提示信息', //数据提交等待的滚动条
waitMsg:'保存数据,请稍候...', //滚动条提示的内容
success:function(form,action){
var message = action.result.message;
if(message == null){
Ext.Msg.alert("提示信息","用户信息添加成功!");
store.reload();
addUserWin.hide();
}else{
Ext.Msg.alert("提示信息",message);
}
},
failure:function(form,action){
Ext.Msg.alert('提示信息',"新用户添加失败!");
return;
}
});
}else {
Ext.Msg.alert("提示信息","表单有错误,请正确填写!");
}
}},
{handler:function(){userForm.form.reset();},text:'重置'},
{handler:function(){addUserWin.hide();},text:'关闭'}]
});
}
addUserWin.show();
}
/**
* 删除用户信息
*/
function delForm(userId)
{
Ext.Msg.confirm('提示信息','你确定要执行删除操作吗?',function(btn){
if(btn == 'yes')
{
/**
* 数据提交的一种方式:Ext.Ajax.request({});
*/
Ext.Ajax.request({
url:'../user/delUser.action',
params:{userId:userId},
method:'post',
success:function(o)
{
var info = Ext.decode(o.responseText);
Ext.Msg.alert("提示信息",info.message);
store.reload();
return ;
},
failure:function(form,action)
{
Ext.Msg.alert("提示信息","用户信息删除失败!");
return ;
}
});
}
});
}
/**
* 批量删除事件
*/
function delUserAll()
{
//grid中复选框被选中的项
var rows = grid.getSelectionModel().getSelections();
//user_id:所有选中的用户Id的集合使用','隔开,初始化为空
var user_id = '';
for(var i = 0;i<rows.length;i++)
{
if(i>0)
{
user_id = user_id+','+rows[i].get('userId');
}else{
user_id = user_id+rows[i].get('userId');
}
}
//没有选择要执行操作的对象
if(user_id == "")
{
Ext.Msg.alert("提示信息","请选择要删除的对象");
return ;
}else{
Ext.Msg.confirm("提示信息","请确定要执行删除操作吗?",function (btn){
if(btn == 'yes')
{
Ext.Ajax.request({
url:"../user/delAllUser.action",
params:{id:user_id},
method:'post',
success:function(o){
var info = Ext.decode(o.responseText);
Ext.Msg.alert("提示信息",info.message);
store.reload();
return ;
},
failure:function(form,action){
Ext.Msg.alert("提示信息","用户信息删除失败!");
}
});
}
});
}
}
/**
* 修改用户信息
* 参数userId:修改对象的Id
*/
function updateForm(userId)
{
editUserForm();
var userForm = Ext.getCmp("editForm").getForm();
Ext.Ajax.request({
url:'../user/doGetOne.action',
params:{userId:userId},
method:'post',
//从struts2.0里返回的参数
success:function(o)
{
//读取action传递过来的对象参数
//docode:解码(解析)一个JSON字符串对象
var user = Ext.decode(o.responseText);
//用户编辑窗口的打开
editUser(user);
//将对象信息显示在对应的form文本框中
userForm.form.findFiled('userInfo.userId').setValue(user.userInfo.userId);
userForm.form.findFiled('userInfo.userName').setValue(user.userInfo.userName);
userForm.form.findFiled('userInfo.pwd').setValue(user.userInfo.pwd);
userForm.form.findFiled('rPwd').setValue(user.userInfo.pwd);
}
});
}
/**
* 用户信息编辑窗口
*/
function editUser(user){
var userForm = Ext.getCmp("editForm").getForm();
//得到用户编辑的窗口的对象
var editUserWin = Ext.getCmp("editWin");
//当为空的时候将进行实例化
if(editUserWin == null)
{
editUserWin = new Ext.Window({
id:'editWin',
width:500,
x:100,
y:100,
modal:true,
resizable:false,
closeAction:"hide",
title:'用户信息修改',
items:[userForm],
buttons:[
{text:'保存',handler:function(){
if(userForm.form.isValid())
{
/**
* 数据提交的第二种方式:form.doAction('submit',{});
*/
userForm.form.doAction('submit',{
url:'../user/updUser.action',
params:{userId:userForm.form.findField('userInfo.userId').getValue()},
method:'post',
waitTitle:'提示信息',
waitMsg:'数据处理中,请稍后....',
//从struts2.0里不需要返回的参数
success:function(form,action)
{
Ext.Msg.alert("提示信息","用户信息修改成功!");
//查询的数据集合store刷新,实现页面自动刷新的效果
store.reload();
//将窗口关闭时候,window. hide()方法是隐藏,因此并不会真正销毁窗口对象
editUserWin.hide();
return ;
},
failure:function(form,action)
{
Ext.Msg.alert("提示信息","用户信息修改失败");
return ;
}
});
}else
{
Ext.Msg.alert("提示信息","表单有错误,请重新填写!");
}
}},
{text:'关闭',handler:function(){editUserWin.hide();}}]
});
}
editUserWin.show();
}
/**
* 重置页面查询表单
*/
function resetForm()
{
Ext.getCmp("queryForm").getForm().reset();
}
/**
* 每行单元格点击事件
*/
function renderPage(grid,rowIndex,columnIndex,e)
{
//触发事件的对象的Id
var id = grid.getStore().getAt(rowIndex).data['userId'];
switch(columuIndex)
{
case 3:delForm(id);
break;
/**
*case 4:updateForm(id);
* break;
*/
default:break;
}
}
// --></script>
</head>
<body>
<div id="searchPanel">
</div>
<div id="centerPanel">
</div>
<div id="mainDiv"></div>
</body>
</html>
发表评论
-
Add a StatusBar to a window
2011-08-10 22:30 1002<html> <head> <t ... -
ExtJs表格点击超链接获取行的值
2011-08-03 23:53 1687grid双击事件,并得到单 ... -
extjs
2011-07-31 10:42 750var record_start=0; columns:[n ... -
ExtJs分页精解(java应用)
2011-07-28 21:48 1105ExtJs的分页做的相当出色!在此,我们简单的分析一下它的分页 ... -
.“Extjs之进度条的控制”
2011-07-28 21:12 2947<%@ Page Language="C#&q ... -
ExtJs实现EditGrid中的增删改查操作(2)
2011-07-27 23:18 45342.本例是在ExtJs官方提供 ... -
ExtJS GridPanel分页、添加、删除、修改
2011-07-27 23:07 2278CheckboxSelectionModel是grid的选择模 ... -
extjs做的添加,删除给大家分享一下.加载数据的数据
2011-07-27 23:05 1486<!DOCTYPE html PUBLIC " ... -
extjs
2011-07-24 14:14 884我想改变默认extjs字体的大小,应该怎么做? AJAX读 ... -
http://huoyunshen888.iteye.com/admin/blogs/new
2011-07-24 13:23 890我用extjs+struts1.2做文件上传时,当文件上传成功 ... -
ext
2011-07-24 09:50 1124Ext.Ajax.request({ url:'get ... -
ExtJS 初步應用 ProgressBar
2011-07-06 22:51 1015<!DOCTYPE HTML PUBLIC " ... -
extjs combox
2011-07-06 22:24 1113var crdtypeStore_CX = new Ext.d ... -
extjs开发包
2011-07-05 21:24 719
相关推荐
可以读写Ext2,以Ext2方式挂载Ext3文件系统(不支持Ext3日志),不支持中文! It provides Windows NT4.0/2000/XP/2003/Vista/2008 with full access to Linux Ext2 volumes (read access andwrite access). This ...
EXT,全称EXT JS,是一种基于JavaScript的开源前端框架,主要应用于构建富互联网应用程序(Rich Internet Applications,简称RIA)。EXT3.jar是EXT框架的一个版本,它包含EXT库的Java版本,通常用于Java Web应用程序...
1. **支持多种EXT文件系统**: Ext2Read不仅支持EXT2,还支持更先进的EXT3和EXT4文件系统。EXT4是目前Linux发行版广泛采用的文件系统,其特点是速度快、支持大文件和大量文件。 2. **查看与复制**: 用户可以像在...
在Windows操作系统中,由于默认不支持Linux文件系统如EXT4,因此无法直接读取或写入EXT4格式的分区。但有一些第三方工具可以帮助我们解决这个问题,其中之一就是Ext2Fsd。Ext2Fsd是一个免费的开源软件,专门设计用于...
标题中的"Ext2IFS windows"表明我们正在讨论一个与Windows操作系统相关的软件,该软件的主要功能是支持挂载Linux的ext文件系统。在Windows环境中,通常无法直接读取或写入Linux系统的ext2、ext3或ext4分区,而Ext2...
《深入理解ext4_utils:三星线刷ROM打包利器》 在Android系统开发和维护领域,三星线刷ROM的打包工具ext4_utils是一个不可或缺的实用程序。这个工具集专注于处理ext4文件系统,一种广泛用于Linux内核的高性能日志...
EXT4,全称为Fourth Extended File System,是Linux操作系统中广泛使用的日志文件系统之一,它在2008年被引入Linux内核。EXT4在EXT3的基础上进行了多项改进,以提升性能、可靠性和可扩展性。这个源码包包含了EXT4...
在Windows操作系统中,由于文件系统不兼容性,通常无法直接访问Linux系统中的Ext3或Ext4分区。然而,有了第三方工具如Ext2Fsd,Windows用户可以实现对这些Linux文件系统的读取和写入操作。本文将详细介绍如何在...
EXT4.2.1是一个广泛使用的JavaScript框架,主要用于构建用户界面和富互联网应用程序(RIAs)。这个安装包可能包含了EXT的各个组件、示例、文档和必要的库文件,以帮助开发者快速搭建功能丰富的Web应用。 EXT的核心...
支持Ext2/Ext3/Ext4, HFS 和 ReiserFS,只读。 There are a number of evident merits of the program, which you should know. First of all,DiskInternals Linux Reader is absolutely free. Secondly, the ...
包含3个工具:make_ext4fs、simg2img、kusering.sh。 1. 解压system.img为system.img.ext4。命令:simg2img system.img system.img.ext4 2. 创建system.img.ext4挂载目录tmp; 命令:mkdir tmp; 3. 挂载system....
在Android系统中,对设备进行刷机或者系统更新时,经常需要处理ext4文件系统。本文将深入探讨如何使用`ext4-utils`工具集来创建`make_ext4fs`和`simg2img`这两个关键工具,这对于理解Android系统底层工作原理以及...
在Android系统中,EXT4文件系统是广泛使用的主文件系统,用于存储应用程序、系统文件和其他数据。EXT4-extractor是一个专为Android设计的工具,它能够帮助开发者和故障排除人员解析EXT4格式的镜像文件,将其转换为一...
EXT是一个流行的JavaScript库,特别适用于构建富客户端应用。EXT2.0.2是EXT库的一个较早版本,它提供了一套完整的组件系统,包括表格(Grid)、面板(Panel)、窗口(Window)等,用于创建复杂的Web界面。在这个特定...
在Android开发中,ext4文件系统打包是系统镜像制作的重要一环。本文档将详细介绍在Android平台上使用make_ext4fs工具打包ext4文件系统镜像的过程,并对相关的操作注意事项进行说明。同时,文档也会涉及使用simg2img...
《jcifs-ext-0.9.4.jar:CAS集成AD域的关键组件》 在现代企业IT环境中,身份验证和授权是网络安全的核心环节。Java社区中的jcifs-ext库扮演了重要角色,特别是在集成Active Directory(AD)域服务时。jcifs-ext-...
在Ext.js中,`Ext.Store`是用来管理数据的类,它通常与各种UI组件(如Grid、ComboBox等)关联,用于存储和检索数据。然而,获取`Ext.Store`的方式并不像获取其他Ext组件那样直接,因为Store并不是一个具有可视界面的...
Ext 4.0是Sencha公司开发的一个JavaScript框架的重要版本,专用于构建富客户端Web应用程序。这个框架基于组件模型,提供了丰富的用户界面组件和强大的数据管理能力,使得开发者能够创建功能强大、交互性强的Web应用...
EXT日志管理系统是一款高效、强大的日志管理工具,专为处理和分析大量系统、应用程序或网络设备的日志数据而设计。EXT在日志管理领域的应用广泛,尤其对于开发者和运维人员来说,它提供了便捷的方式来监控、排查问题...
《深入理解make_ext4fs:构建EXT4文件系统的利器》 在Linux系统中,EXT4文件系统因其高效、稳定和广泛支持的特点,被广泛应用。在开发和维护过程中,有时我们需要手动创建EXT4文件系统,这时就需要用到`make_ext4fs...