Extjs20091204

本文介绍如何使用ExtJS创建一个具备增删改查功能的网格面板。通过实例展示了如何配置列模型、数据存储、分页工具栏等关键组件,并实现刷新、添加、编辑和删除等操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head runat="server">

    <title>无标题页</title>

    <link rel="Stylesheet" type="text/css" href="ExtJS/resources/css/ext-all.css" />

    <link rel="Stylesheet" type="text/css" href="ExtJS/resources/css/xtheme-green.css" />

    <script type="text/javascript" src="ExtJS/adapter/ext/ext-base.js"></script>

    <script type="text/javascript" src="ExtJS/ext-all.js"></script>

    <script type="text/javascript" src="ExtJS/ext-lang-zh_CN.js"></script>

    <style type="text/css">

    .panel_icon { background-image:url(images/first.gif)}

    .center_icon { background-image:url(images/house.png)}

    </style>

</head>

<body>

    <form id="form1" runat="server">

    <div>

    <script type="text/javascript">    

    function ready()

    {

        //添加下面这句,有助于当鼠标放在Ext自带的图标上时能够显示提示的功能

        Ext.QuickTips.init();

 

        var url = "jsonGrid.aspx?Param=select";

        var sm = new Ext.grid.CheckboxSelectionModel();

 

        var cm = new Ext.grid.ColumnModel

        ([        

            sm,new Ext.grid.RowNumberer({header:"编号",width:50}),

            {header:"编号",dataIndex:"ID",width:10,hidden:true},

            {header:"标题",dataIndex:"TypeCName",width:100,editor:new Ext.form.TextField()},

            {header:"英文名称",dataIndex:"TypeEName",width:100,editor:new Ext.form.TextField()},

            {header:"状态",dataIndex:"DelFlag",width:100,renderer:function(value){if(value==false) {return "显示";} else {return "隐藏";}}},

            {header:"添加日期",dataIndex:"AddDate",width:100,renderer:Ext.util.Format.dateRenderer('Y年m月d日')}

        ]);

        cm.defaultSortable = true; 

        var fields = 

            [

                {name:"ID"},

                {name:"TypeCName"},

                {name:"TypeEName"},

                {name:"DelFlag"},

                {name:"AddDate"}

           ];

        var store = new Ext.data.Store

        ({

            proxy:new Ext.data.HttpProxy({url:url}),

            reader:new Ext.data.JsonReader({totalProperty:"totalPorperty",root:"root",fields:fields})

        });

        store.load({params:{start:0,limit:15}});

 

        var pagingBar = new Ext.PagingToolbar

        ({

            displayInfo:true,

            emptyMsg:"没有数据显示",

            displayMsg:"显示从{0}条数据到{1}条数据,共{2}条数据",

            store:store,

            pageSize:15,

            items:

            [

                ' ',

                {

                    enableToggle: true,

                    text: '刷新',

                    cls: 'x-btn-text-icon details',icon:"images/plugin.gif",

                    toggleHandler: function(btn, pressed)

                    {

                        //动态加重新载数据列表

                        Ext.getCmp("MenuGridPanel").store.reload();

                    }

                }

                , 

                '-', 

                {

                    enableToggle: true,//TypeTable实体类 ID PID TypeEName TypeCName DelFlag AddDate 

                    text: '添加',

                    cls: 'x-btn-text-icon details',icon:"images/plugin.gif",

                    toggleHandler: function(btn, pressed)

                    {

                        var win = new Ext.Window

                        ({

                             title:"添加记录窗口",

                             width:257,

                             height:200,

                             layout:'form',

                             modal:true,

                             resizable:false,

                             iconCls :"center_icon", 

                             items:

                             [

                                 {

                                    xtype:"form",

                                    height:200,

                                    labelPad : 0,// 标签与字段录入框之间的空白

                                    bodyStyle : 'padding-top:3px',

                                    frame : true,

                                    defaultType : 'textfield',

                                    labelAlign : 'right',

                                    labelWidth : 55,

                                    defaults : // 容器中组件默认统一配置选项 

                                    { 

                                        allowBlank : false,width : 150// 字段宽度                            

                                    },

                                    items :

                                    [

                                         {fieldLabel:"标题",id:"TypeCName",maxLength:50},

                                         {fieldLabel:"英文名称",id:"TypeEName",maxLength:50},

                                         {xtype:"datefield",fieldLabel:"添加日期",id:"AddDate",renderer:Ext.util.Format.dateRenderer('Y年m月d日 h:m:s')},

                                         {fieldLabel:"状态",id:"DelFlag",maxLength:4}

                                    ]

                                 }

                             ],

                             buttons:

                             [

                                 {

                                    xtype:"button",text:"确定提交",cls:"x-btn-text-icon",icon:"images/add.gif",

                                    handler:function()

                                    {

                                        //这里获取添加表单的数据 

                                        var typeCName = Ext.getCmp("TypeCName").getValue();

                                        var typeEName = Ext.getCmp("TypeEName").getValue();

                                        var addDate = Ext.getCmp("AddDate").getValue();

                                        var delFlag = Ext.getCmp("DelFlag").getValue();

                                        //同时可以对上面获取的数据添加验证

                                        Ext.Ajax.request

                                        ({

                                            http://www.cnblogs.com/mogen_yin/admin/%22jsonGrid.aspx?Param=add",//添加 url 具体在哪个页面实现添加功能

                                            params:{ParamName:"good",TypeCNameParam:typeCName},//客户端页面向服务器断传递数据,前面是参数名称,后面是参数值,多个参数用逗号分隔开

                                            success:function(respose,option)

                                            {

                                                //如果在服务器端正确处理了数据并且返回了正确的值得就执行该函数的语句

                                                //将服务器端正确返回的json字符串转换横Ext对象,然后就能够使用

                                                var result = Ext.util.JSON.decode(respose.responseText);

                                                //当确定添加成功后再执行下面的语句,动态加载数据列表

                                                Ext.getCmp("MenuGridPanel").store.reload();

                                            },

                                            failure:function()

                                            {

                                                //如果在服务器端处理数据发生了异常,就执行该函数的语句

                                            }

                                        });

                                    }

                                 },

                                 {

                                    xtype:"button",text:"关闭退出",cls:"x-btn-text-icon",icon:"images/delete.gif",

                                    handler:function()

                                    {

                                        win.destroy();

                                    }

                                 }

                             ],

                             buttonAlign:"center"

                        });

                        win.show();

                    }

 

                }, ' '

                , 

                '-', 

                {

                    enableToggle: true,//TypeTable实体类 ID PID TypeEName TypeCName DelFlag AddDate 

                    text: '编辑',

                    cls: 'x-btn-text-icon details',icon:"images/plugin.gif",

                    toggleHandler: function(btn, pressed)

                    {                        

                        var TypeENameValue;

                        var TypeCNameValue;

                        var DelFlagValue;

                        var AddDateValue;

                        var IDValue;

                        var rows = Ext.getCmp("MenuGridPanel").getSelections();

                        if(rows.length>=1)

                        {

                            IDValue = rows[0].json.ID;

                            TypeENameValue = rows[0].json.TypeEName;

                            TypeCNameValue = rows[0].json.TypeCName;

                            DelFlagValue = rows[0].json.DelFlag;

                            AddDateValue = rows[0].json.AddDate;

                        }

                        else

                        {

                            Ext.Msg.alert("提示消息","请选择一行数据然后才能够编辑。<br/>如果选择多行数据,默认情况下只对第一行有效!");return false;

                        }

                        var win = new Ext.Window

                        ({

                             title:"编辑修改记录窗口",

                             width:257,

                             height:200,

                             layout:'form',

                             modal:true,

                             resizable:false,

                             iconCls :"center_icon", 

                             items:

                             [

                                 {

                                    xtype:"form",

                                    height:200,

                                    labelPad : 0,// 标签与字段录入框之间的空白

                                    bodyStyle : 'padding-top:3px',

                                    frame : true,

                                    defaultType : 'textfield',

                                    labelAlign : 'right',

                                    labelWidth : 55,

                                    defaults : // 容器中组件默认统一配置选项 

                                    { 

                                        allowBlank : false,width : 150// 字段宽度                            

                                    },

                                    items :

                                    [

                                         {fieldLabel:"标题",id:"TypeCName",maxLength:50,value:TypeCNameValue},

                                         {fieldLabel:"英文名称",id:"TypeEName",maxLength:50,value:TypeENameValue},

                                         {xtype:"datefield",fieldLabel:"添加日期",value:AddDateValue,id:"AddDate",renderer:Ext.util.Format.dateRenderer('Y年m月d日 h:m:s')},

                                         {fieldLabel:"状态",id:"DelFlag",maxLength:5,value:DelFlagValue}

                                    ]

                                 }

                             ],

                             buttons:

                             [

                                 {

                                    xtype:"button",text:"确定修改",cls:"x-btn-text-icon",icon:"images/add.gif",

                                    handler:function()

                                    {

                                        //这里获取表单的数据 

                                        var typeCName = Ext.getCmp("TypeCName").getValue();

                                        var typeEName = Ext.getCmp("TypeEName").getValue();

                                        var addDate = Ext.getCmp("AddDate").getValue();

                                        var delFlag = Ext.getCmp("DelFlag").getValue();

                                        //同时可以对上面获取的数据添加验证

                                        Ext.Ajax.request

                                        ({

                                            http://www.cnblogs.com/mogen_yin/admin/%22jsonGrid.aspx?Param=edit",//添加 url 具体在哪个页面实现编辑修改功能

                                            params:{ParamName:"good",TypeCNameParam:typeCName},//客户端页面向服务器断传递数据,前面是参数名称,后面是参数值,多个参数用逗号分隔开

                                            success:function(respose,option)

                                            {

                                                //如果在服务器端正确处理了数据并且返回了正确的值得就执行该函数的语句

                                                //将服务器端正确返回的json字符串转换横Ext对象,然后就能够使用

                                                var result = Ext.util.JSON.decode(respose.responseText);

                                                //当确定添加成功后再执行下面的语句,动态加载数据列表

                                                Ext.getCmp("MenuGridPanel").store.reload();

                                            },

                                            failure:function()

                                            {

                                                //如果在服务器端处理数据发生了异常,就执行该函数的语句

                                            }

                                        });

                                    }

                                 },

                                 {

                                    xtype:"button",text:"关闭退出",cls:"x-btn-text-icon",icon:"images/delete.gif",

                                    handler:function()

                                    {

                                        win.destroy();

                                    }

                                 }

                             ],

                             buttonAlign:"center"

                        });

                        win.show();

                    }

 

                }, ' '  

                , 

                '-', 

                {

                    enableToggle: true,//TypeTable实体类 ID PID TypeEName TypeCName DelFlag AddDate 

                    text: '删除',

                    cls: 'x-btn-text-icon details',icon:"images/plugin.gif",

                    toggleHandler: function(btn, pressed)

                    {                        

                        var TypeENameValue;

                        var TypeCNameValue;

                        var DelFlagValue;

                        var AddDateValue;

                        var IDValue;

                        var rows = Ext.getCmp("MenuGridPanel").getSelections();

                        if(rows.length>=1)

                        {

                            IDValue = rows[0].json.ID;

                            TypeENameValue = rows[0].json.TypeEName;

                            TypeCNameValue = rows[0].json.TypeCName;

                            DelFlagValue = rows[0].json.DelFlag;

                            AddDateValue = rows[0].json.AddDate;

                        }

                        else

                        {

                            Ext.Msg.alert("提示消息","请选择一行数据然后才能够删除。<br/>如果选择多行数据,默认情况下只删除第一行。<br/>如果需要删除多条数据,请选择批量删除!");return false;

                        }

                        var win = new Ext.Window

                        ({

                             title:"确定删除窗口",

                             width:257,

                             height:200,

                             layout:'form',

                             modal:true,

                             resizable:false,

                             iconCls :"center_icon", 

                             items:

                             [

                                 {

                                    xtype:"form",

                                    height:200,

                                    labelPad : 0,// 标签与字段录入框之间的空白

                                    bodyStyle : 'padding-top:3px',

                                    frame : true,

                                    defaultType : 'textfield',

                                    labelAlign : 'right',

                                    labelWidth : 55,

                                    defaults : // 容器中组件默认统一配置选项 

                                    { 

                                        allowBlank : false,width : 150// 字段宽度                            

                                    },

                                    items:

                                    [

                                         {fieldLabel:"标题",id:"TypeCName",maxLength:50,value:TypeCNameValue},

                                         {fieldLabel:"英文名称",id:"TypeEName",maxLength:50,value:TypeENameValue},

                                         {xtype:"datefield",fieldLabel:"添加日期",value:AddDateValue,id:"AddDate",renderer:Ext.util.Format.dateRenderer('Y年m月d日 h:m:s')},

                                         {fieldLabel:"状态",id:"DelFlag",maxLength:5,value:DelFlagValue}

                                    ]

                                 }

                             ],

                             buttons:

                             [

                                 {

                                    xtype:"button",text:"确定删除",cls:"x-btn-text-icon",icon:"images/add.gif",

                                    handler:function()

                                    {

                                        //这里获取表单的数据 

                                        var typeCName = Ext.getCmp("TypeCName").getValue();

                                        var typeEName = Ext.getCmp("TypeEName").getValue();

                                        var addDate = Ext.getCmp("AddDate").getValue();

                                        var delFlag = Ext.getCmp("DelFlag").getValue();

                                        //同时可以对上面获取的数据添加验证

                                        Ext.Ajax.request

                                        ({

                                            http://www.cnblogs.com/mogen_yin/admin/%22jsonGrid.aspx?Param=edit",//添加 url 具体在哪个页面实现编辑修改功能

                                            params:{ParamName:"good",TypeCNameParam:typeCName},//客户端页面向服务器断传递数据,前面是参数名称,后面是参数值,多个参数用逗号分隔开

                                            success:function(respose,option)

                                            {

                                                //如果在服务器端正确处理了数据并且返回了正确的值得就执行该函数的语句

                                                //将服务器端正确返回的json字符串转换横Ext对象,然后就能够使用

                                                var result = Ext.util.JSON.decode(respose.responseText);

                                                //当确定添加成功后再执行下面的语句,动态加载数据列表

                                                Ext.getCmp("MenuGridPanel").store.reload();

                                            },

                                            failure:function()

                                            {

                                                //如果在服务器端处理数据发生了异常,就执行该函数的语句

                                            }

                                        });

                                    }

                                 },

                                 {

                                    xtype:"button",text:"关闭退出",cls:"x-btn-text-icon",icon:"images/delete.gif",

                                    handler:function()

                                    {

                                        win.destroy();

                                    }

                                 }

                             ],

                             buttonAlign:"center"

                        });

                        win.show();

                    }

 

                }, ' '  

            ]   

        });

        var grid = new Ext.grid.GridPanel 

        ({

            id:"MenuGridPanel",

            renderTo:document.body,

            layout:"fit",

            frame:true,

            border:true,

            width:700,

            height:450,

            autoScroll:true,  

            store:store,

            sm:sm,

            cm:cm,

            viewConfig:{forceFit: true},

            title:'<img style="height:auto; width:auto;" src="images/first.gif" /> Ext2.2全新功能版系列之--确定删除',

            bbar:pagingBar

        });

    }

    </script>    

    <script type="text/javascript">

    Ext.onReady(ready);

    </script>

    </div>

    </form>

</body>

</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值