天天看點

ext2.2打造全新功能grid系列--閱增删改篇(四)

下面先看看效果圖吧

ext2.2打造全新功能grid系列--閱增删改篇(四)

上面的效果可以說明是在資料浏覽篇的基礎上擴充而來,雖然僅僅是增加了幾個按鈕,但是當初并沒有想到這方面,隻是剛剛才有了這個想法

在選中某條記錄後就可以對目前的這條資料進行編輯了,當然,你還可以增加新的記錄, 你還可以根據需要增加更多的操作按鈕

這裡具體的操作功能都沒有實作,主要是因為前幾篇可以借鑒.

下面就看看選中某條記錄後的效果吧

ext2.2打造全新功能grid系列--閱增删改篇(四)

感覺還是很漂亮的.

下面把頁面設計代碼完整張貼出來.

  CODE: <%@ Page Language="C#" AutoEventWireup="true" CodeFile="gridEdit.aspx.cs" Inherits="gridEdit" %>

<!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" target="_blank" rel="external nofollow" />

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

    <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 = "jsonGrid3.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; 128

        var fields =

            [

                {name:"ID"},

                {name:"TypeCName"},

                {name:"TypeEName"},

                {name:"Message"},

                {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:12}});

        var pagingBar = new Ext.PagingToolbar

        ({

            displayInfo:true,

            emptyMsg:"沒有資料顯示",

            displayMsg:"目前第{0}--{1}條,共{2}條資料",

            store:store,

            pageSize:12

        });

        var grid = new Ext.grid.GridPanel

        ({

            id:"MenuGridPanel",region:"center",

            store:store,           

            cm:cm,

            sm:sm,

            renderTo:document.body,

            layout:"fit",

            frame:true,

            border:true,

            width:700,

            autoWidth:true,

            height:450,

            autoScroll:true, 

            viewConfig:{forceFit: true},

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

            bbar:pagingBar

        });

        //這個窗體用于展示某行資料的詳細資訊

        var formPanel = new Ext.Panel

        ({

            title:"編輯記錄",

            region:"east",

            width:357,

            height:160,

            layout:'fit',

            split: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 : 250// 字段寬度                           

                    },

                    items :

                    [

                        {fieldLabel:"标題",id:"TypeCName",style:"color:red;",readOnly:true},

                        {fieldLabel:"英文名稱",id:"TypeEName",style:"color:green;",readOnly:true},

                        {xtype:"textarea",fieldLabel:"内容",id:"Message",style:"color:blue;",height:160,readOnly:true},

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

                        {fieldLabel:"狀态",id:"DelFlag",maxLength:5}

                    ],

                    buttons:

                    [                         

                      {                   

                            text: '添加',

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

                            handler: function()

                            {

                                //事件處理比較簡單 自己嘗試處理

                            }

                        },       

                        {                   

                            text: '編輯',

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

                            handler: function()

                            {                             

                            }

                        },           

                        {                   

                            text: '隐藏/顯示',

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

                            handler: function()

                            {

                                //事件處理比較簡單 自己嘗試處理

                            }

                        },             

                        {

                            text: '删除',

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

                            handler: function()

                            {

                                //事件處理比較簡單 自己嘗試處理

                            }

                        }

                    ]

                }

            ]

        });

        grid.on("rowclick",function(thisGrid,rowIndex,e)

        {

            var row = thisGrid.getStore().getAt(rowIndex).data;           

            Ext.getCmp("TypeCName").setValue(row.TypeCName);

            Ext.getCmp("TypeEName").setValue(row.TypeEName);

            if(row.Message.indexOf("<br/>")>-1)

            {

                var newMessage1 = row.Message.replace(//s/img,"");

                var newMessage2 = newMessage1.replace(//<br///>/img,"/r/n");

                Ext.getCmp("Message").setValue(newMessage2);

            }

            Ext.getCmp("AddDate").setValue(row.AddDate);

            Ext.getCmp("DelFlag").setValue(row.DelFlag);             

        });               

        var viewPort = new Ext.Viewport

        ({

            title:"grid與form搭配活用",

            layout:'border',

            id:"viewPort",           

            items:

            [

                grid,formPanel

            ],

            renderTo:document.body

        });

    }

    </script> 

    <script type="text/javascript">

    Ext.onReady(ready);

    </script>

    </div>

    </form>

</body>

</html>

繼續閱讀