iteye_165 2010-04-10 10:40
浏览 503
已采纳

怎么让Combobox选择不同值显示不同的表单

我想做个效果,就是选择下拉框中某一项值就显示不同的表单.比如:我选择假期日期,下面就显示一个日期选择框.默认是一个textField...应该怎么做?如图.
[code="js"]
var queryCond=new Ext.form.ComboBox({fieldLabel:'查詢條件',hiddenName:'txtCond',
store:new Ext.data.SimpleStore({fields:['value','text'],data:[['holiday_name','假期名稱'],['holiday_date','假期日期'],['holiday_type','假期類型']]}),
mode:'local',triggerAction:'all',valueField:'value',displayField:'text',anchor:'50%',value:'holiday_name'
});

    queryCond.on('change',function(combox){
        var val=combox.getValue();
        if(val=='holiday_date'){
            queryKey=new Ext.form.DateField({fieldLabel:'請選擇日期',id:'holidaydate',name:'txtKey',anchor:'50%'});                
        }else if(val=='holiday_type'){
            queryKey=new Ext.form.ComboBox({fieldLabel:'<b>假期類型</b>',allowBlank:false,hiddenName:'txtKey',id:'holidaytype',
                store:new Ext.data.SimpleStore({fields:['value','text'],data:[['法定假日','法定假日'],['公司假','公司假'],['其他假日','其他假日']]}),
                mode:'local',triggerAction:'all',valueField:'value',displayField:'text',value:'法定假日',anchor:'25%'
            });
        }else{
            queryKey=new Ext.form.TextField({fieldLabel:'關鍵字',id:'holidayother',name:'txtKey',anchor:'80%'});
        }

    });

    var form=new Ext.form.FormPanel({
        bodyStyle:'padding:20px;',modal:true,id: 'holidayForm',labelWidth:100,labelAlign: 'right',
        url:'',border: false,defaultType: 'textfield',
        items:[queryCond,queryKey],
        buttons:[{text:'查詢',handler:''},{text:'取消',handler:function(){win.close();}}]
    });
    var win=new Ext.Window({
        title:'查詢假期窗口',modal:true,autoScroll:true,layout: 'fit',
        width:500,height:250,
        items:[form]
    });
    win.show();

[/code]

  • 写回答

3条回答 默认 最新

  • zhoujuan520 2010-04-12 11:02
    关注

    从你的代码中看出来,你碰到的问题是,你选择了日期,却不创建日期组件,当你从formpanel中移除某个组件或者增加某个组件后必须调用组件的容器的doLayout()方法,还有一定必须注意,某些布局是不支持增减组件的.譬如layout:'border'

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)