Ext小总结
window.allOrderListXlyView_orderFunc_consumeXLY = function(recordId,orders_id,orderNO){
Ext.getCmp('allOrderListXlyView').fireEvent('expensecalendar',recordId,orders_id,orderNO);
}
2.去defind.js页面添加弹出页面以及弹出的控制层
var consumeXLYView_id_order = 'consumeXLYView_order';
var consumeXLYView_order = 'App.view.order.allOrderXly.consumeXLYView';
var consumeXLYController_order = 'App.controller.order.allOrderXly.consumeXLYController';
3.在弹出view时注意
extend:'Ext.window.Window',
initComponent:function(){
Ext.apply(this,{
width:450,
height:450,
autoShow:true,
modal:true,
animCollapse : true,
animateTarget : Ext.getBody(),
layout:'fit',
items:[{
xtype:'form',
margin:'10 10 10 10',
scrollable:true,
items:[
{
xtype:'displayfield',fieldLabel:'消费订单号',name:'orderNO',width:150,labelWidth:80
},{
xtype:'fieldcontainer',
width:'100%',name:'refundNumContainer',
//hidden:true,
items:[{
xtype:'displayfield',fieldLabel:'电子码',name:'codeField',width:150,labelWidth:60
},{
xtype:'fieldcontainer',layout:{type:'hbox',align:'middle'},width:'100%',
items:[
{
xtype:'numberfield',fieldLabel:'退款数量',minValue:'1',name:'count',width:150,labelWidth:60,value:'1',
allowBlank:false,blankText:'退款数量不能为空'
},{
xtype:'tbtext',text:'',name:'refundAbleTbtext'
},
]
}]
},
{
xtype:'displayfield',fieldLabel:'产品名称',name:'printName',width:150,labelWidth:60
},
{
xtype:'displayfield',fieldLabel:'已消费数量',name:'consumeNum',width:150,labelWidth:80
},
]
}],
buttons:[{
text:'取消',
cls:'btn btn-danger',
handler:function(o){
o.up('window').close();
}
},{
text:'提交',
name:'btnOk',
cls:'btn btn-success'
}]
});
this.callParent(arguments);
}
});
extend:'Ext.app.Controller',
views:[consumeXLYView_order],
init:function(){
var currentObjView = null;
var refundApplyCodeIds = [];
this.control({
'#consumeXLYView_order':{
'afterrender':function(o){
currentObjView = o;
Ext.Ajax.request({
url:__APP__+'/XlyOrders/listOrdersConsumeCodes',
params:{
orders_id:o.orderId
},
timeout:60000,
success:function(response,opts){
var text=Ext.decode(response.responseText);
if(text.success==false){
o.close();
Ext.MessageBox.alert('提示',text.msg);
}else {
var code = text.lists;
if(code.length>0)refundApplyCodeIds = code;
//console.log(code.length);
if(code.length==1){
o.down('fieldcontainer[name=refundNumContainer]').show();
o.down('displayfield[name=codeField]').setValue(code[0].code);
o.down('displayfield[name=orderNO]').setValue(o.orderNO);
var refundAbleNum = code[0].canRefundNum;
var printName = code[0].printName;
//console.log(printName);
o.down('numberfield[name=num]').setMaxValue(refundAbleNum);
o.down('displayfield[name=printName]').setValue(printName);
o.down('tbtext[name=refundAbleTbtext]').setText('(可退款数量'+refundAbleNum+')');
}else if(code.length>1){
o.down('numberfield[name=num]').disable();
o.down('fieldcontainer[name=refundCodeContainer]').show();
o.down('displayfield[name=orderNO]').setValue(o.orderNO);
Ext.Array.each(code,function(mv){
o.down('fieldcontainer[name=refundCodeContainer]').down('checkboxgroup').insert(0,{
boxLabel:mv.code, name:'codes', checkboxInputId:mv.id,submitValue:false
});
});
}
}
},
failure: function(response, opts) {
o.close();
Ext.MessageBox.alert('服务器出错',response.status);
}
});
}
},
'#consumeXLYView_order checkbox[name=selectAll]':{
'change':function(o,newValue,oldValue){
var checkboxgroup = Ext.ComponentQuery.query('fieldcontainer[name=refundCodeContainer] checkbox[name=codes]');
Ext.Array.each(checkboxgroup,function(mv){
mv.setValue(newValue);
});
}
},
'#consumeXLYView_order button[name=btnOk]':{
click:function(o){
//var checkboxs = Ext.ComponentQuery.query('numberfield[name=num]');
//var codeStr = [];
//Ext.Array.each(checkboxs,function(mv){
// if(mv.getValue()==true)codeStr.push(mv.checkboxInputId);
//});
//var code_id = codeStr.join(',');
//if(refundApplyCodeIds.length==1)code_id = refundApplyCodeIds[0].id;
o.up('window').down('form').submit({
waitMsg:'提交中...',
clientValidation: true,
submitEmptyText:false,
url: __APP__+"/index.php/XlyOrders/consumeOrder", //提交后调整页面的路径也相当于地址
params:{
order_id:currentObjView.orderId
},
success: function(form, action){
o.up('window').close();
Ext.getStore('order.allOrderXly.allOrderListStore').loadPage(1);
Ext.toast({
html: action.result.msg,
title: '提示',
width: 400,
align: 't'
});
},
failure: function(form, action) {
switch (action.failureType) {
case Ext.form.action.Action.CLIENT_INVALID:
Ext.Msg.alert('退款失败', '无效输入');
break;
case Ext.form.action.Action.CONNECT_FAILURE:
Ext.Msg.alert('退款失败', '联网失败');
break;
case Ext.form.action.Action.SERVER_INVALID:
Ext.Msg.alert('退款失败', action.result.msg);
}
}
});
}
}
});
}
});
Ext小总结的更多相关文章
- 【python018--函数参数】
1.形参和实参 >>> def MyFirstFunction(name): '函数定义过程中的name是叫形参' #因为Ta只是一个形式,表示占据一个参数位置 p ...
- 【翻译】要理解Ext JS 5小工具
原版的:Understanding Widgets in Ext JS 5 在Ext JS 5,引入了新的"widgetcolumn",支持在网格的单元格中放置组件. 同一时候,还 ...
- 【翻译】了解Ext JS 5的小部件
原文:Understanding Widgets in Ext JS 5 在Ext JS 5,引入了新的"widgetcolumn",支持在网格的单元格中放置组件.同时,还在Ext ...
- Extjs 项目中常用的小技巧,也许你用得着(5)--设置 Ext.data.Store 传参的请求方式
1.extjs 给怎么给panel设背景色 设置bodyStyle:'background:#ffc;padding:10px;', var resultsPanel = Ext.create('Ex ...
- Ext JS - 问答
Ext JS - 问答 在下面你将可以找到关于Ext JS 的最常见问题的答复.如果没有找到您所需的答复,请访问 Ext JS 论坛或者提交一个支持申请. 如果你确信你的问题可以对本页有补充,请让我们 ...
- 编辑 Ext 表格(二)——— 编辑表格元素
一.编辑单元格 Ext 中通过配置表格的属性 plugins 来设置表格是否可编辑, 表格的配置具体如下: var gridTable = Ext.create('Ext.grid.Panel', { ...
- 编辑 Ext 表格(一)——— 动态添加删除行列
一.动态增删行 在 ext 表格中,动态添加行主要和表格绑定的 store 有关, 通过对 store 数据集进行添加或删除,就能实现表格行的动态添加删除. (1) 动态添加表格的行 gridS ...
- extjs 学习小窍门
一.从form中获取field的三个方法: 1.Ext.getCmp('id'); 2.FormPanel.getForm().findField('id/name'); 3.Ext.get('id/ ...
- Ext JS 4 新特性2:配置项属性(config)之一
Ext JS 4 新特征2:配置项属性config 最新版本的Ext JS 4.2的另外一个伟大的新特征就是增加了configuration配置项属性,当我们在创建一个新类的时候,经常性的要设置某某属 ...
随机推荐
- SQL注入—我是如何一步步攻破一家互联网公司的
最近在研究Web安全相关的知识,特别是SQL注入类的相关知识.接触了一些与SQL注入相关的工具.周末在家闲着无聊,想把平时学的东东结合起来攻击一下身边某个小伙伴去的公司,看看能不能得逞.不试不知道,一 ...
- iOS之应用发布中的一些细节
Bundle identifier Xcode中 Target -> General中的bundle identifier ; info.plist中的Bundle identifier; 证书 ...
- GCD封装的个人理解和应用
GCD封装的个人理解和应用 特点 >>将GCD封装,使我们从繁琐的方法记忆中解脱出来,能够直接快速的应用. 使用方法 1.将工程中的GCD文件中的9个文件拖入自己的工程中(你自己最好建一个 ...
- [Android]对MVC和MVP的总结
以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/5036289.html 经历过的客户端的架构分为这么几个阶段: ...
- 转一篇简洁的UIView动画编程方法
iOS 中的 UIView 动画编程其实还是很简单的,像 CSS3 一样,在给定的时间内完成状态连续性的变化呈现.比如背景色,Frame 大小,位移.翻转,特明度等. 以前我使用的编程方式都是用下面 ...
- iOS-多线程之GCD(原创)
前言 GCD 全称 Grand Central DisPath NSOperation便是基于GCD的封装 基础知识 1.GCD的优势 (1)为多核的并行运算提出了解决方案 (2)GCD会自动利用更多 ...
- C# .net dotnet属性定义属性,以提供显示明称,默认值
//使用显示名称初始化 System.ComponentModel.DisplayNameAttribute 类的新实例. displayName 显示名称 [DisplayName("we ...
- Oracle监听服务启动失败案例
在ORACLE测试服务器上还原恢复了一个数据库后,启动监听服务时出现了TNS-12541, TNS-12560,TNS-00511之类的错误,具体情况如下所示: [oracle@getlnx01 ad ...
- 机器学习实战笔记(Python实现)-00-readme
近期学习机器学习,找到一本不错的教材<机器学习实战>.特此做这份学习笔记,以供日后翻阅. 机器学习算法分为有监督学习和无监督学习.这本书前两部分介绍的是有监督学习,第三部分介绍的是无监督学 ...
- 【转】hive优化之--控制hive任务中的map数和reduce数
一. 控制hive任务中的map数: 1. 通常情况下,作业会通过input的目录产生一个或者多个map任务. 主要的决定因素有: input的文件总个数,input的文件大小,集群设置 ...