70.资金管理-福利表管理 Extjs 页面
1.
<%@ page language="java" 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>福利信息</title>
<script type="text/javascript">
var boon = new Boon();
var tabId = Ext.getCmp('mainTab').getActiveTab().id.split('_')[1];
juage(tabId,"boon",boon,"boon");
</script> </head>
<body>
<div id="boon" ></div>
</body>
</html>
2、
/**
* 福利信息
* @author sux 2011-02-23
* @memberOf {TypeName}
*/
var Boon = Ext.extend(Ext.grid.EditorGridPanel,{
id: 'boonId',
constructor: function(){
Ext.form.Field.prototype.msgTarget = 'title';
var number = new Ext.grid.RowNumberer();
var sm = new Ext.grid.CheckboxSelectionModel();
var boonStore = new Ext.data.JsonStore({
url: 'boon_edit.action',
root: 'root',
totalProperty: 'totalProperty',
fields: ['boonId','boonName','boonMoney','boonPercent','boonRmark']
});
var cm = new Ext.grid.ColumnModel([
number, sm,
{
header: '编号',
dataIndex: 'boonId',
align: 'center'
},{
header: '名称',
dataIndex: 'boonName',
align: 'center',
editor: new Ext.form.TextField({
allowBlank: false,
blankText: '不能为空'
})
},{
header: '总额',
dataIndex: 'boonMoney',
align: 'center',
editor: new Ext.form.NumberField({
allowBlank: false,
blankText: '不能为空'
})
},{
header: '百分比',
dataIndex: 'boonPercent',
align: 'center',
editor: new Ext.form.NumberField({
allowBlank: false,
blankText: '不能为空'
})
},{
header: '备注',
dataIndex: 'boonRemark',
align: 'center',
editor: new Ext.form.TextArea()
}]);
Boon.superclass.constructor.call(this, {
width: Ext.getCmp('mainTab').getActiveTab().getInnerWidth(),
height: Ext.getCmp('mainTab').getActiveTab().getInnerHeight(),
/**表格高度自适应 document.body.clientHeight浏览器页面高度 start**/
monitorResize: true,
doLayout: function() {
this.setWidth(document.body.clientWidth-205);
this.setHeight(document.body.clientHeight-140);
Ext.grid.GridPanel.prototype.doLayout.call(this);
} ,
viewConfig: {
forceFit: true
},
sm: sm,
cm: cm,
store: boonStore,
tbar: new Ext.Toolbar({
items: [{
text: '删除',
iconCls: 'delete',
id: 'boon_delete',
hidden: 'true',
handler: delBoonFn
},{
text: '新增',
id: 'boon_add',
hidden: 'true',
iconCls: 'add',
handler: newBoonFn
},{
text: '保存或修改',
iconCls: 'save',
id: 'boon_saveorupdate',
hidden: 'true',
handler: modifyBoonFn
}]
}),
bbar: new PagingToolbar(boonStore, 20)
});
boonStore.load({
params: {
start: 0,
limit: 20
}
});
}
});
//删除
delBoonFn = function(){
gridDel('boonId', 'boonId','boon_delete.action'); };
//新增
newBoonFn = function(){
var DefaultRecord = new Ext.data.Record.create([{name: 'boonId', mapping: 0},{name: 'boonName', mapping: 1},
{name: 'boonMoney', mapping: 2},{name: 'boonPercent', mapping: 3},{name: 'boonRemark', mapping: 4}]);
var num = Ext.getCmp('boonId').getStore().getCount();
var newRecord = new DefaultRecord({
boonId: num+1,
boonName: '',
boonMoney: '',
boonPercent: '',
boonRemark: ''
});
Ext.getCmp('boonId').getStore().insert(0,newRecord);
};
//保存或修
modifyBoonFn = function(){
var modifiedRecords = Ext.getCmp('boonId').getStore().getModifiedRecords();
var boons = reJson(modifiedRecords);
Ext.Ajax.request({
url: 'boon_modify.action',
waitTitle: '提示',
waitMsg: '正在保存数据...',
method: 'post',
params: {
json: boons
},
success: boonModifySuccessFn,
failure: boonModifyfailureFn
})
};
boonModifySuccessFn = function(response, options){
var datas = Ext.util.JSON.decode(response.responseText);
Ext.Msg.alert('提示',datas.msg,function(){
Ext.getCmp('boonId').getStore().load({
params: {
start: 0,
limit: 20
}
});
});
};
//保存失败
boonModifyfailureFn = function(response, options){
Ext.Msg.alert('提示','连接失败',function(){})
};
//转成json
reJson = function(modifiedRecords){
var count = modifiedRecords.length;
var boons='';
//有修改或保存
if(count > 0){
boons = "[";
for(i=0; i<count; i++){
boons += "{";
var boonId = modifiedRecords[i].get('boonId');
var boonName = modifiedRecords[i].get('boonName');
var boonMoney = modifiedRecords[i].get('boonMoney');
var boonPercent = modifiedRecords[i].get('boonPercent');
var boonRemark = modifiedRecords[i].get('boonRemark');
boons += '"boonId":'+boonId+', "boonName":"'+boonName+'","boonMoney":'+boonMoney+',"boonPercent":'+boonPercent+',"boonRemark":"'+boonRemark+'"}';
if( i != count-1)
boons += ","
}
boons += "]"
}
return boons;
}
70.资金管理-福利表管理 Extjs 页面的更多相关文章
- 69.资金管理-税率表管理extjs 页面
1. <%@ page language="java" import="java.util.*" pageEncoding="UTF-8&quo ...
- 80.用户管理 Extjs 页面
1 <%@ page language="java" import="java.util.*" pageEncoding="UTF-8" ...
- 74.资金管理-员工工资配置 extjs 页面
1. <%@ page language="java" import="java.util.*" pageEncoding="UTF-8&quo ...
- 82.角色管理Extjs 页面
1. <%@ page language="java" import="java.util.*" pageEncoding="UTF-8&quo ...
- SNF开发平台WinForm之四-开发-主细表管理页面-SNF快速开发平台3.3-Spring.Net.Framework
4.1运行效果: 4.2开发实现: 4.2.1 有了第一个程序的开发,代码生成器的配置应该是没有问题了,我们只要在对应的数据库中创建我们需要的表结构就可以了,如下: 主表结构如下: ...
- SQLSERVER新建表的时候页面分配情况是怎样的?
SQLSERVER新建表的时候页面分配情况是怎样的? 再次感谢sqlskill网站和转载sqlskill网站文章并翻译的人,因为您们的转载和翻译让小弟又学习到新的东西o(∩_∩)o 文章中用到的工具: ...
- 给ecshop后台增加管理功能页面
给ecshop后台增加管理功能页面 比如我们增加一个统计报表叫做 物流费用统计报表 放在后台“报表统计”栏目中 具体操作步骤: 第一步,我们要添加一个菜单到后台,然后设置语言项,最后设置权限,这样,后 ...
- django学习-22.admi管理后台页面的文案展示等相关配置
目录结果 1.前言 2.完整的操作步骤 2.1.第一步:对[settings.py]里的相关常量的值做如下修改 2.2.第二步:重启django项目[helloworld]的服务 2.3.第三步:重新 ...
- OracleDBA之表管理
下面是Oracle表管理的部分,用到的测试表是oracle数据库中scott用户下的表做的测试,有的实验也用到了hr用户的数据,以下这些东西是我的麦库上存的当时学Oracle的学习笔记今天拿出来和大家 ...
随机推荐
- JPA 与 JDBC 的区别和基本用法
JPA 概念 JPA(Java Persistence API)用于对象持久化的 API,是 Java EE 5.0 平台标准的 ORM 规范,使得应用程序以统一的方式访问持久层. 与 JDBC 的对 ...
- [Luogu] P3258 [JLOI2014]松鼠的新家
题目描述 松鼠的新家是一棵树,前几天刚刚装修了新家,新家有n个房间,并且有n-1根树枝连接,每个房间都可以相互到达,且俩个房间之间的路线都是唯一的.天哪,他居然真的住在”树“上. 松鼠想邀请小熊维尼前 ...
- vue中路由
关于每次点击链接都要刷新页面的问题众所周知,开发单页应用就是因为那丝般顺滑的体验效果,如果每次点击都会刷新页面… 出现这个的原因是因为使用了window.location来跳转,只需要使用使用rout ...
- type="application/javascript"
type="application/javascript" html script 标签中 type有如下这些值,请问分别是什么意思,在什么情况下使用? type="te ...
- -sql语句练习50题(Mysql学习练习版)
–1.学生表 Student(s_id,s_name,s_birth,s_sex) –学生编号,学生姓名, 出生年月,学生性别 –2.课程表 Course(c_id,c_name,t_id) – –课 ...
- 终于理解java的classpath!
JAVA 的CLASSPATH 上面这样是可以的!!!!哇, 再也不会出现编译或是运行的时候,class 找不到的问题了.终于明白为什么了. java -cp /ysr/my-app P 这条命 ...
- [Vue @Component] Handle Errors and Loading with Vue Async Components
Because async components are not bundled with your app, they need to be loaded when requested. This ...
- ZOJ 3827 Information Entropy(数学题 牡丹江现场赛)
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do? problemId=5381 Information Theory is one of t ...
- sql 分组取每组的前n条或每组的n%(百分之n)的数据
sql 分组取每组的前n条或每组的n%(百分之n)的数据 sql keyword: SELECT * ,ROW_NUMBER() OVER(partition by b.UserID order by ...
- OC中APPDelegate[[UIApplication shareApplication]delegate]]Swift实现
直接上代码: var myDelegate:AppDelegate? myDelegate = UIApplication.sharedApplication().delegate as? AppDe ...