zoukankan      html  css  js  c++  java
  • ExtJs 4.2.1 复选框数据项动态加载(更新一下)

    最近在做博客项目,后台管理用的是ExtJs4.2.1版本,因为是初学所以在使用的时候也遇到不少的这样或那样的问题,也写了不少这方面的博客,今天要写的博客是关于复选框数据项动态的加载功能,以前也没用过,初次用,不知道怎么动态加载,静态加载很容易,添加itmes就可以了,于是我在网上找找有关这方面的博客,找到一篇,不过遗憾的是,这种方法太糟糕了,不是很方便,于是找到了一个很好的解决方法:

     

    //点击编辑弹出的formpanel
            var formPanel = new Ext.FormPanel({
                //labelAlign: 'top',
                bodyStyle: 'padding:5px 20px 0 5px',
                autoScroll: true,
                layout: 'form',
                items: [
                {
                    xtype: 'textfield',
                    id: 'title',
                    name: 'title',
                    anchor: '100%'
                }, {
                    xtype: 'htmleditor',
                    id: 'context',
                    name: 'context',
                    border: true,
                    plugins: [
    	        	    Ext.create('Ext.zc.form.HtmlEditorImage')
    	            ],
                    height: 400,
                    anchor: '100%'
                }, {
                    xtype: 'checkboxgroup',
                    id: 'lblName',
                    name: 'lblName',
                    columns: 6,
                    border: true,
                    anchor: '100%'
                }
              ],
                buttonAlign: 'center',
                buttons: [
            {
                text: '保存',
                icon: '../../../Images/extjs/disk.png',
                handler: function () {
                    var text = form.getForm().findField('context').getValue();
                    alert(text);
                }
            }, {
                text: '关闭',
                icon: '../../../Images/extjs/cross.png',
                handler: function () {
                    win.close(this);
                }
            }
          ]
            });
    
            //通过extjs的ajax获取用户文章关联的标签数据
            Ext.Ajax.request({
                url: '/Manage/GetLableNameByUserIdAndArticleId',
                params: {
                    articleid: rows[0].get('Id')
                },
                success: function (response) {
                    var obj = eval("(" + response.responseText + ")");
                    var len1 = obj.alldata.length;
                    var len2 = obj.data.length;
                    if (obj.data == null || len1 == 0) {
                        return;
                    }
                    var checkboxgroup = Ext.getCmp("lblName");
                    for (var i = 0; i < len1; i++) {
                        var checkboxObj = {
                            boxLabel: obj.alldata[i].Name,
                            name: 'cb-' + i,
                            checked: false
                        };
                        for (var j = 0; j < len2; j++) {
                            if (obj.alldata[i].Id == obj.data[j].Id) {
                                checkboxObj.checked = true;
                            }
                        }
                        var checkbox = new Ext.form.Checkbox(checkboxObj);
                        checkboxgroup.items.add(checkbox);
                    }
                    formPanel.doLayout(); //重新调整版面布局  
                }
            });
    
            //点击编辑弹出的windows(formpanel作为window的items)
            var win = Ext.create("Ext.window.Window", {
                title: "编辑",       //标题
                draggable: false,
                icon: '../../../Images/extjs/pencil.png',
                height: 600,                          //高度
                 850,                           //宽度
                layout: "fit",                        //窗口布局类型
                modal: true, //是否模态窗口,默认为false
                resizable: false,
                items: [formPanel]
            });
    
            //给form赋值
            formPanel.getForm().reset();
            var contents = rows[0].get('Contents');
            formPanel.getForm().findField("title").setValue(rows[0].get('Title'));
            formPanel.getForm().findField("context").setValue(decodeURI(contents));
            //window显示
            win.show();
    

     

      

     

    分析:

    我现在讲解下,我是怎么动态加载复选框选项数据的,首先,初始化formpanel(formpanel里的数据项(items)创建了一系列的form(有textfield,htmleditor,checkboxgroup),创建完毕后,再通过Extjs的ajax获取数据项的数据(这个数据就是放在checkboxgroup里的)       

    var checkboxgroup = Ext.getCmp("lblName");
    for (var i = 0; i < len1; i++) {
    var checkboxObj = {
    boxLabel: obj.alldata[i].Name,
    name: 'cb-' + i,
    checked: false
    };
    for (var j = 0; j < len2; j++) {
    if (obj.alldata[i].Id == obj.data[j].Id) {
    checkboxObj.checked = true;
    }
    }
    var checkbox = new Ext.form.Checkbox(checkboxObj);
    checkboxgroup.items.add(checkbox);
    }
    formPanel.doLayout(); //重新调整版面布局
    

      

    然后,通过Ext.getCmp()方法,获取到刚才在formpanel里创建的checkboxgroup组件,然后通过for循环创建checkbox(这就是将刚才通过ajax获取的数据项数据进行初始化),然后,保存在checkboxgroup里面,接下来,就是最最重要的一步,当for循环结束后,你要重新调整版面布局,这时调用doLayout()方法,这样就动态的渲染到formpanel里的checkboxgroup里面,就完成了动态加载的效果!

     

    //---------------------------------------更新部分--------------------------------------
    

    注意:上面所述确实能够动态加载checkbox,但是(我最讨厌但是了),用form.submit()方法提交的时候不能够将选中的checkbox提交到后台(用上面的代码,有兴趣的可以试试),所以这种方法行不通,不过我又找到了一个新方法,点击这里查看

    //获取grid选中的数据
        var sm = Ext.getCmp("gridPanel").getSelectionModel();
        var rows = sm.getSelection();
        if (!sm.hasSelection()) {
            Ext.MessageBox.show({
                title: '提示',
                msg: '请选择一行数据进行操作!',
                buttons: Ext.MessageBox.OK,
                icon: Ext.MessageBox.INFO
            });
            return;
        }
    
        var myCheckboxGroup;//定义checkboxgroup组件
    
        //通过 Ext.Ajax.request()方法获取用户文章关联的标签数据
        Ext.Ajax.request({
            url: '/Manage/GetLableNameByUserIdAndArticleId',
            async: false,
            params: {
                articleid: rows[0].get('Id')
            },
            success: function (response) {
                var text = response.responseText;
                var obj = eval("(" + text + ")");
                var len1 = obj.data.alldata.length;
                var len2 = obj.data.mydata.length;
    
                var myCheckboxItems = [];//创建checkbox 数据项
                for (var i = 0; i < len1; i++) {
                    var checkboxObj = {
                        boxLabel: obj.data.alldata[i].Name,
                        name: 'cbLable',
                        inputValue: obj.data.alldata[i].Id,
                        padding: '0 20px 5px 0',
                        checked: false
                    };
                    for (var j = 0; j < len2; j++) {
                        if (obj.data.alldata[i].Id == obj.data.mydata[j].Id) {
                            checkboxObj.checked = true;
                        }
                    }
                    myCheckboxItems.push(checkboxObj);//保存checkbox 数据项
                }
                //新建checkboxgroup组件(将checkboxItems数据项作为它的数据项)
                myCheckboxGroup = new Ext.form.CheckboxGroup({
                    xtype: 'checkboxgroup',
                    columns: 6,
                    items: myCheckboxItems
                });
            }
        });
    
        //点击编辑弹出的formpanel
        var formPanel = new Ext.FormPanel({
            //labelAlign: 'top',
            bodyStyle: 'padding:5px 20px 0 5px',
            autoScroll: true,
            layout: 'form',
            items: [{
                xtype: 'textfield',
                name: 'title',
                anchor: '100%'
            }, {
                xtype: 'htmleditor',
                border: true,
                id: 'context',
                plugins: [
                        Ext.create('Ext.zc.form.HtmlEditorImage')
                    ],
                height: 400,
                anchor: '100%'
            },
                myCheckboxGroup
              ],
            buttonAlign: 'center',
            buttons: [
            {
                text: '保存',
                icon: '../../../Images/extjs/disk.png',
                handler: function () {
                    if (!formPanel.getForm().isValid()) {
                        return;
                    }
                    //
                    var opera = formPanel.getForm().getValues(true).replace(/&/g, ', ');
                    formPanel.getForm().submit({
                        url: '/Manage/SaveArticle',
                        method: 'get',
                        success: function (form, action) {
                            Ext.Msg.alert('Success', action.result.msg);
                            win.close(this);
                        },
                        failure: function (form, action) {
    
                        }
                    });
                }
            }, {
                text: '关闭',
                icon: '../../../Images/extjs/cross.png',
                handler: function () {
                    win.close(this);
                }
            }
          ]
        });
    
    
    
        //点击编辑弹出的windows(formpanel作为window的items)
        var win = Ext.create("Ext.window.Window", {
            title: "编辑",       //标题
            draggable: false,
            icon: '../../../Images/extjs/pencil.png',
            height: 600,                          //高度
             850,                           //宽度
            layout: "fit",                        //窗口布局类型
            modal: true, //是否模态窗口,默认为false
            resizable: false,
            items: [formPanel]
        });
    
        //给form重置后赋值
        formPanel.getForm().reset();
        var contents = rows[0].get('Contents');
        formPanel.getForm().findField("title").setValue(rows[0].get('Title'));
        formPanel.getForm().findField("context").setValue(decodeURI(contents));
        //window显示
        win.show();
    

      

      又来总结一下:

    其实他的解决思路是这样的:首先创建好checkbox和checkboxgroup然后再创建formpanel,再将之前创建好的checkboxgroup作为formpanel的items,这样,就没有问题了,而我之前做的是先创建formpanel然后再动态添加checkbox,再doLayout(),这样只能显示,而不能获取(不推荐)!所以这种方法解决了问题,不过还有一个小的技术点要提醒一下就是使用Ext.Ajax.request()方法的时候要设置为同步async: false,否则则出现,checkbox不显示,道理很简单,因为ajax是异步的所以当面板加载后才去创建checkboxgroup,这样当然就不行了,跟我之前的问题也差不多,希望大家不能犯我一样的错!

    2014-03-20

     

  • 相关阅读:
    redis 内存管理与数据淘汰机制(转载)
    Memcached特性及优缺点
    二叉树深度优先遍历和广度优先遍历
    电商 秒杀系统 设计思路和实现方法(转载)
    6种负载均衡算法
    解决like '%字符串%'时索引不被使用的方法
    哪些情况下索引会失效?
    PreferenceActivity详解
    sun.misc.BASE64Encoder在Eclipse中不能直接使用的原因和解决方案
    单点登录原理与简单实现
  • 原文地址:https://www.cnblogs.com/zhangwei595806165/p/3608265.html
Copyright © 2011-2022 走看看