`
wj.king
  • 浏览: 70764 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

使用Ext的Grid,Form,Dialog来实现分页列表,创建,修改,删除功能(续) javasc

阅读更多

http://hi.baidu.com/%5Follie/blog/item/8ffb66fa96b1b51da9d3116f.html

 

前面已经把列表,分页,删除等部分说完了,这里再把创建和修改说说,基本的功能就差不多了.

创建

在这里,创建和修改者是用Dialog的形式来做的,首先则需要创建相应的DIV:

<!-- add div -->
    <div id="a-addInstance-dlg" style="visibility:hidden;">
        <div class="x-dlg-hd">添加权限</div>
        <div class="x-dlg-bd">
            <div id="a-addInstance-inner" class="x-layout-inactive-content">
                <div id="a-addInstance-form"></div>
            </div>
        </div>       
    </div>

之后就是在这个DIV里创建Form了,直接用Ext的Form组件:

createNewForm : function() {       
                this.name_tf = new Ext.form.TextField({
                    fieldLabel : '名称',
                    name : 'name',
                    allowBlank : false
                });
                this.description_tf = new Ext.form.TextField({
                    fieldLabel : '描述',
                    name : 'description'
                });
                this.addForm = new Ext.form.Form({
                    labelAlign : 'right',
                    url : '/wit/add.shtml'
                });
                this.addForm.column({
                    width : 430,
                    labelWidth : 120,
                    style : 'margin-left : 8px; margin-top : 8px;'
                });
                this.addForm.fieldset(
                    {id : 'desc', legend : '请填写字段值'},
                    Grid.name_tf,
                    Grid.description_tf
                );
                this.addForm.applyIfToFields({ width : 255 });
                this.addForm.render('a-addInstance-form');
                this.addForm.end();
            }

之后别忘了在加载的时候调用这个方法:

this.createNewForm();

Form窗体定义完,现在可以处理前面说的过那个创建按钮的事件了,在这里事件处理的方法名为doAdd:

doAdd : function() {
                if (!Grid.addInstanceDlg) {
                    Grid.addInstanceDlg = Grid.createNewDialog('a-addInstance-dlg');
                    Grid.addInstanceDlg.addButton('重置', Grid.resetForm, Grid.addInstanceDlg);
                    Grid.addInstanceDlg.addButton('保存', Grid.saveNewForm, Grid.addInstanceDlg);
                    var layout = Grid.addInstanceDlg.getLayout();
                    layout.beginUpdate();
                    var t = new Ext.ContentPanel('a-addInstance-inner', {title : 'create account'});
                    layout.add('center', new Ext.ContentPanel('a-addInstance-inner', {title : '添加权限'}));
                    layout.endUpdate();           
                }                   
                Grid.addInstanceDlg.show();           
            }

首先用Grid.createNewDialog创建一个LayoutDialog,之后再把添加里的特有的按钮加上去,然后更新一下Dialog的布局,把它显示出来,这时就可以看到添加的窗体了:

add

呵,窗体做的很难看,因为只是为了实现功能,没有在这方便下什么功夫.

Grid.createNewDialog用于创建和修改时创建对话框,代码如下:

createNewDialog : function(title) {
                var newDialog = new Ext.LayoutDialog(title, {
                    modal : true,
                    autoTabs : true,
                    proxyDrag : true,
                    resizable : false,
                    width : 480,
                    height : 302,
                    shadow : true,
                    center : {
                        autoScroll : true,
                        tabPosition : 'top',
                        closeOnTab : true,
                        closeOnTab : true,
                        alwaysShowTabs : false
                    }
                });
                newDialog.addKeyListener(27, newDialog.hide, newDialog);
                newDialog.addButton('取消', function() { newDialog.hide(); } );
                return newDialog;           
            }

如 果添加成功,则自动关闭这个Dialog,并重新加载列表,如果添加失败,只是简单的弹出一个对话框,提示失败,其实这里可以做的更人性化一些,可以在服 务器端传回错误的原因,比如某字段有问题,可以红色显示出其输入框等等.这里服务端返回的JSON数据与删除返回的一样.

处理代码如下:

saveNewForm : function() {
                if (Grid.addForm.isValid()) {
                    Grid.addForm.submit({
                        waitMsg : '正在保存数据...',
                        reset : true,
                        failure : function(form, action) {
                            Ext.MessageBox.alert('友情提示', action.result.info);
                        },
                        success : function(form, action) {
                            Grid.addInstanceDlg.hide();
                            Grid.ds.reload();
                        }
                    });
                } else {
                    Ext.MessageBox.alert('错误', '字段填写不正确!');
                    Grid.name_tf.focus();
                }
            }

修改

修改则和创建差不多了,不同的有两点,一是事件是在列表的行上双击,来触发事件,弹出修改对话框,另一个则是需要在显示对话框的同时,把所要修改的记录的数据加载进来.

首先在列表加上事件捕捉:

this.grid.on('rowdblclick', this.onRowDbClick, this);   

下面则是处理这个事件的代码:

onRowDbClick : function(grid, rowIndex, e) {
                var selectId = this.ds.data.items[rowIndex].id;
                var roleData = new Ext.data.Store({
                    proxy : new Ext.data.HttpProxy({url : '/wit/edit.shtml?id=' + selectId}),
                    reader : new Ext.data.JsonReader({}, ['id', 'name', 'description']),
                    remoteSort : false
                });
                roleData.on('load', function() {
                    Grid.updateId = roleData.getAt(0).data['id'];
                    Grid.name_show.setValue(roleData.getAt(0).data['name']);
                    Grid.description_show.setValue(roleData.getAt(0).data['description']);
                    if (!Grid.updateInstanceDlg) {
                        Grid.updateInstanceDlg = Grid.createNewDialog('a-updateInstance-dlg');
                        Grid.updateInstanceDlg.addButton('保存', Grid.saveUpdateForm, Grid.updateInstanceDlg);
                        var layout = Grid.updateInstanceDlg.getLayout();
                        layout.beginUpdate();
                        layout.add('center', new Ext.ContentPanel('a-updateInstance-inner', {title : '修改权限'}));
                        layout.endUpdate();
                    }
                    Grid.updateInstanceDlg.show();
                });
                roleData.load();
            }

这里做了两件事,一个是把欲修改的数据加载到本地, 服务端返回的数据结构为:

([{"id":"12","description":"test role 12","name":"puras 12"}])

一个是将数据置入Form窗体的字段中,并将Dialog显示出来.修改的Form与创建的相似:

createEditForm : function() {
                this.name_show = new Ext.form.TextField({
                    fieldLabel : '名称',
                    name : 'name',
                    allowBlank : false
                });
                this.description_show = new Ext.form.TextField({
                    fieldLabel : '名称',
                    name : 'description'
                });
                this.editForm = new Ext.form.Form({
                    labelAlign : 'right',
                    url : '/wit/edit_ok.shtml'
                });
                this.editForm.column({width : 430, labelWidth : 120, style : 'margin-left : 8px; margin-top : 8px;'});
                this.editForm.fieldset(
                    {legend : '请更新字段值'},
                    Grid.name_show,
                    Grid.description_show
                );
                this.editForm.applyIfToFields({width : 255});
                this.editForm.render('a-updateInstance-form');
                this.editForm.end();
            }

这个Form对应的Div为:

<!-- update div -->
    <div id="a-updateInstance-dlg" style="visibility:hidden;">
        <div class="x-dlg-hd">修改权限</div>
        <div class="x-dlg-bd">
            <div id="a-updateInstance-inner" class="x-layout-inactive-content">
                <div id="a-updateInstance-form"></div>
            </div>
        </div>
    </div>

双击某条记录,则会弹出修改Dialog了,大概的样子如下:

edit

修改的处理事件与添加类似,需要注意的地方就是ID是怎么传过去的:

saveUpdateForm : function() {
                if (Grid.editForm.isValid()) {
                    Grid.editForm.submit({
                        params : { id : Grid.updateId},
                        waitMsg : '正在更新数据...',
                        reset : false,
                        failure : function(form, action) {
                                Ext.MessageBox.alert('友情提示', action.result.info);
                            },
                        success : function(form, action) {
                            Grid.updateInstanceDlg.hide();
                            Grid.ds.reload();
                        }
                    });                   
                } else {
                    Ext.MessageBox.alert('错误', '字段填写不正确!');
                }
            }

到此就Over啦,列表,添,删,改都OK了.在没有做的时候,总是感觉找不到入口点,做完之后才发现,原来自己担心的问题,都不是问题,哈,想想,还是挺简单的.

作者:puras

分享到:
评论

相关推荐

    使用Ext的Grid,Form,Dialog来实现分页列表,创建,修改,删除功能

    本文将详细介绍如何使用Ext的Grid、Form和Dialog组件来实现分页列表、创建、修改和删除功能。 1. **Ext Grid组件**:Grid是Ext的核心组件之一,用于展示数据列表。它可以轻松地实现数据的分页、排序、过滤等功能。...

    Android Dialog各种实现

    在Android开发中,Dialog...总的来说,Android Dialog是与用户交互的重要工具,理解并熟练使用各种Dialog可以帮助提升应用的用户体验。通过系统提供的Dialog和自定义Dialog,开发者可以根据应用场景选择最适合的方案。

    js实现的dialog

    本文将详细介绍如何使用纯 JavaScript 来创建一个功能完备的 Dialog 模块,以及涉及到的相关知识点。 首先,`lhgdialog` 文件可能是实现 Dialog 的核心库,而 `lhgcore.js` 可能是该库的基础组件或核心功能模块。这...

    Android高级应用源码-自定义列表选择Dialog,适用网络请求数据.zip

    这个“Android高级应用源码-自定义列表选择Dialog,适用网络请求数据.zip”文件提供了一个实例,展示了如何创建一个可以加载网络数据并展示在列表中的自定义Dialog。下面将详细阐述相关知识点: 1. **自定义Dialog*...

    dialog弹框上实现下拉列表功能,有二级关联菜单选项功能ExpandableListViewDemo-master

    dialog弹框上实现下拉列表功能,有二级关联菜单选项功能ExpandableListViewDemo-master 通过设置属性,可实现只显示一个Group的子菜单 , 显示全部Group的子菜单 。需要自己设置就可以了。

    各种Android Dialog创建及其监听事件实现

    我们经常会需要在Android界面上弹出一些对话框 比如询问用户或者让用户选择 关于Android Dialog的使用方法 已经有很多blog做出了详细的介绍(比如博客:7种形式的Android Dialog使用举例) 但是只是给出了创建各种...

    Ext.ux.Upload.Dialog使用

    在IT行业中,`Ext.ux.Upload.Dialog`是一个用于Ext JS框架的第三方组件,它扩展了标准的对话框(Dialog)功能,提供了文件上传的能力。这个组件通常被用于Web应用程序,以便用户可以方便地向服务器上传文件。下面...

    Extjs的学习资料

    2. **使用Ext的Grid, Form, Dialog来实现分页列表、创建、修改、删除功能**: - Grid:展示数据,支持分页、排序、选择行等操作。 - Form:用于数据输入和编辑,可以包含各种表单字段,如文本框、复选框、下拉框等...

    Android中用Dialog来做使用引导/新手引导页面

    本文将详细介绍如何使用自定义Dialog来实现这样的功能,特别针对初次使用APP的用户,通过半透明蒙版高亮目标并配以说明文字或图片,提升用户体验。 首先,我们要明白Dialog在Android中的角色。Dialog是一种轻量级的...

    ext3.0所有控件演示代码

    通过`Ext.grid.GridPanel`创建表格,设置`store`来绑定数据,利用`columns`定义列配置。此外,还可以实现行选择、行编辑、行拖放等功能,提升用户体验。 2. 表单(Form):EXT3.0的表单组件允许开发者创建复杂的...

    Ext常用功能开发总结

    创建表格主要通过`Ext.grid.Panel`类来完成,需要配置`columns`属性来定义表格的列,`store`属性来绑定数据源。 #### 表格数据的构造 数据通常存储在`Ext.data.Store`对象中,可以使用`fields`配置数据结构,`data`...

    使用Dialog实现从页面顶部弹出类似搜索的对话框

    在标题“使用Dialog实现从页面顶部弹出类似搜索的对话框”中,我们要探讨的是如何创建一个从屏幕顶部滑出的对话框,模拟常见的搜索功能。这种效果在许多应用程序中都能看到,它提供了简洁且不中断用户体验的方式来...

    Android 创建自定Dialog

    总结,创建自定义Dialog涉及布局设计、DialogFragment的实现、事件监听和可能的扩展功能。理解源码和使用工具能够帮助开发者更好地掌控Dialog的创建过程,从而提供更加个性化和高效的用户交互体验。通过不断实践和...

    Android-Android开发启动app弹出一张广告图片Dialog可以查看大图查看某个图片功能

    这里可以使用类似于之前自定义Dialog的方法,但需要调整布局以适应全屏显示,并且可能需要添加滑动手势来实现图片的左右滑动切换。如果使用新的Activity,可以传递图片URL到新Activity,然后在新Activity中加载图片...

    自定义dialog实现listview长按删除item数据

    本文将深入探讨如何实现一个自定义Dialog来展示ListView,并且允许用户通过长按来删除ListView中的item数据。 首先,我们需要创建自定义Dialog的布局文件。在res/layout目录下创建一个新的XML文件,例如`dialog_...

    jquery dialog简单实现插件

    jQuery Dialog 是一个非常流行的JavaScript库,它为网页提供了一种优雅的方式来创建弹出式对话框。这个插件是基于jQuery框架构建的,主要用于创建模态或非模态的窗口,通常用于显示警告、确认信息或者作为用户交互的...

    仿QQ列表可折叠+自定义Dialog结合

    在Android应用开发中,...综上所述,"仿QQ列表可折叠+自定义Dialog结合"是Android开发中的一个重要实践,它涉及到了数据绑定、用户交互、动画效果以及性能优化等多个方面,开发者需要综合运用多种技术来实现这一功能。

    自定义dialog实现登录框

    在Android开发中,自定义Dialog是一种常见的用户界面(UI)设计技术,用于提供与用户交互的弹出式窗口。通常,我们使用Dialog来显示重要的信息、提示或进行简单的操作,如登录、注册等。本教程将详细介绍如何在...

    android 用Button+dialog实现spinner

    这篇博客“android 用Button+dialog实现spinner”正是探讨了如何结合Button和Dialog来实现这样的功能。 首先,我们要了解Spinner的基本用法。Spinner通常通过Adapter(如ArrayAdapter或CursorAdapter)与数据集关联...

Global site tag (gtag.js) - Google Analytics