titleCollapse:true,//高级搜索点击隐藏显示
添加按钮 》弹出页面
1.添加按钮
//核销  在控制层页面添加页面路径》添加操作按钮》
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时注意
 Ext.define(consumeXLYView_order,{ //这个页面路径是defind.js
   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);
   }
});
 3 在弹出的controller控制层中注意
Ext.define(consumeXLYController_order,{ //这块需要换成与define.js相符的controller路径,这些里面必须与后台接口返回的数据字段相符合,才能显示出来
     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小总结的更多相关文章

  1. 【python018--函数参数】

    1.形参和实参 >>> def MyFirstFunction(name):    '函数定义过程中的name是叫形参'    #因为Ta只是一个形式,表示占据一个参数位置    p ...

  2. 【翻译】要理解Ext JS 5小工具

    原版的:Understanding Widgets in Ext JS 5 在Ext JS 5,引入了新的"widgetcolumn",支持在网格的单元格中放置组件. 同一时候,还 ...

  3. 【翻译】了解Ext JS 5的小部件

    原文:Understanding Widgets in Ext JS 5 在Ext JS 5,引入了新的"widgetcolumn",支持在网格的单元格中放置组件.同时,还在Ext ...

  4. Extjs 项目中常用的小技巧,也许你用得着(5)--设置 Ext.data.Store 传参的请求方式

    1.extjs 给怎么给panel设背景色 设置bodyStyle:'background:#ffc;padding:10px;', var resultsPanel = Ext.create('Ex ...

  5. Ext JS - 问答

    Ext JS - 问答 在下面你将可以找到关于Ext JS 的最常见问题的答复.如果没有找到您所需的答复,请访问 Ext JS 论坛或者提交一个支持申请. 如果你确信你的问题可以对本页有补充,请让我们 ...

  6. 编辑 Ext 表格(二)——— 编辑表格元素

    一.编辑单元格 Ext 中通过配置表格的属性 plugins 来设置表格是否可编辑, 表格的配置具体如下: var gridTable = Ext.create('Ext.grid.Panel', { ...

  7. 编辑 Ext 表格(一)——— 动态添加删除行列

    一.动态增删行 在 ext 表格中,动态添加行主要和表格绑定的 store 有关, 通过对 store 数据集进行添加或删除,就能实现表格行的动态添加删除.   (1) 动态添加表格的行  gridS ...

  8. extjs 学习小窍门

    一.从form中获取field的三个方法: 1.Ext.getCmp('id'); 2.FormPanel.getForm().findField('id/name'); 3.Ext.get('id/ ...

  9. Ext JS 4 新特性2:配置项属性(config)之一

    Ext JS 4 新特征2:配置项属性config 最新版本的Ext JS 4.2的另外一个伟大的新特征就是增加了configuration配置项属性,当我们在创建一个新类的时候,经常性的要设置某某属 ...

随机推荐

  1. MySQL学习笔记 -- 数据表的基本操作

    数据库是一个可以存放数据库对象的容器,数据库对象包括:表.视图.存储过程.函数.触发器.事件.其中,表是数据库最基本的元素,是其他数据库对象的前提条件. 表中的一列称为一个字段,一行称为一条记录. 1 ...

  2. CSS手动改变DIV高宽

    本实例代码可以使DIV可以手动改变大小 效果体验:http://hovertree.com/code/css/resize.htm 代码如下: <!DOCTYPE html> <ht ...

  3. javascript的列表切换

    演示地址:http://wjf444128852.github.io/demo/Carousel/index.html IE兼容性没处理,确切的说不太会,还望指点一二 思路: 1.js获取要给定点击事 ...

  4. JQ中的方法、事件及动画

    css( ) 除了可以为元素添加样式外,还可用来查询元素,某样式值alert($('.cls1').css('width')); //100px(返回带单位的值)注意:原生CSS样式中有-的去掉并且将 ...

  5. SharePoint 2013 工作流平台的选项不可用

    问题描述 当我想创建一个SharePoint 2013 工作流的时候,打开SharePoint 2013 Designer(一下简称SPD),发现没有SharePoint 2013 工作流的选项.原来 ...

  6. Linux入侵检测常用命令

    find / -mtime 0 #0代表目前时间,表示从现在开始到24小时以前,有改动过内容的文件全都会被列出来.如果是3天前24小时内,则使用find / -mtime 3 find /etc -n ...

  7. LINUX下C-C++类软件的诊断

    一般C/C++写程序由于内存.指针等问题在后期的过程都一般会遇到内存等资源泄露.崩溃等问题,对于这些问题,一般从哪个角度解决呢? 下面从几个角度进行总结: 内存泄露 首先需要注意一个问题是top或者h ...

  8. Handler.sendMessage 与 Handler.obtainMessage.sendToTarget比较

    原文地址: http://www.cnblogs.com/android007/archive/2012/05/10/2494766.html 话说在工作中第一次接触android 的Handler ...

  9. 关于安卓APP的启动界面

    刚学安卓App开发的朋友们,可能会遇到一个问题,就是人家的App刚进入会有一个页面出现一会儿后消失,   这个页面可以用来打广告,也可以声明App的主题,所以说这个启动页面至关重要,接下来,我把我的代 ...

  10. 使用Objective-C 计算代码运行时间

    第一种:(最简单的NSDate) NSDate* tmpStartData = [NSDate date]; //You code here... double deltaTime = [[NSDat ...