学习Ext已经有些许时间了,发现实际运用过程中ExtGrid系列还是最为常用的,本来想自己写些话语来总结的,无意间看到有位仁兄早就总结了,故冒犯贴在此处,以便以后翻阅,还望见谅

Ext - Grid
    Grid是Ext框架中一个重要的组成部分。一般建立Grid主要实现数据的增删改查。
   
       建立一个Grid
       Grid一般有三个主要的内容,ds,cm,GridPanel
      
       var ds = new Ext.data.Store();
       var cm = new Ext.grid.ColumnModel();
       var grid = new Ext.grid.GridPanel();
      
        
       如果要页面载入时,Grid不显示,事件触发查询并建立Grid显示。 很简单,将GridPanel建立在事件的function中就可以了。
       如果载入时就显示Grid,这里分几种情况:
                                       (1)页面载入时,Grid显示,并查询和显示出数据。
                                       (2)页面载入时,Grid显示,但不发送请求数据,事件触发查询。该查询条件已固定或不需要条件。
                                       (3)页面载入时,Grid显示,不查询数据,事件触发查询,该查询需要从页面上存在的文本框中获得数据作为条件。
                                   (4)与(3)相同,但是希望在Grid查询过程中有loadMask效果。
       对于1)
            直接在Ext.onReady()中建立GridPanel,并且ds调用load方法。
       对于2)
            在Ext.onReady()中建立GridPanel,而在事件的function中写ds.load()
       对于3)
            在Ext.onReady()中建立GridPanel,而此时的ds为一个假ds,它的作用仅仅是为了能够在页面载入时就显示Grid,而在事件的function中
       则再建立一个带有查询条件的ds,然后用该ds重新配置Grid.grid.reconfigure(ds,cm);
       对于4)
       查询的要求可由grid被新的ds重新配置的方法实现,但是会发现,这样做时,Grid的loadMask效果也不会出现了。有一个方法,就是在事件的
      function中,将Grid的render的div清空,即div.innerHTML="" 之后再重新建立一个Grid。这样做的缺点就是会在有很多代码重复。
       可能还会出现一些其他的function的调用以及无法取得某对象的问题。
      
       以下由第三种情况为例,来说明增删改查。
       建立:
          var fds = new Ext.data.Store();
          var cm = new Ext.grid.ColumnModel([
                       {header:'例子',width:100,dataIndex:'test',
                                 editor:new Ext.form.TextField({
                                          id:'test'
                                 })
                       }
          ]);
          var sm = new Ext.grid.RowSelectionModel();
          var grid = new Ext.grid.EditorGridPanel({
                          ds:fds,
                          cm:cm,
                          sm:sm,
                          width:200,
                          height:200,
                          title:'举例',
                          renderTo:Ext.get("testdiv")
          });
   这里建立EditorGridPanel,是可以进行编辑的Grid.
     1 查询:(点击按钮触发事件)
          function btnclick()
          {
            var Record = Ext.data.Record.create([
                           {name:'test'}
            ]); //此处将record单独提出方便操作
            var ds = new Ext.data.Store({
                          url:'访问的地址',
                          reader:new Ext.data.XmlReader({
                                      record:'item'
                          },Record)
            });
            ds.load();
            grid.reconfigure(ds,cm);
          }
    2 添加
         新建一条数据
         var r = new Record({
               test:'随便举个例子'
         });
        插入到表格指定行,n为要插到这行后(此处取了表格的行数,即插入到最后),m是编辑完毕后focus的位置列数
         var n = grid.getStore().getCount();
         grid.stopEditing();
         grid.getStore().insert(n,r);
         grid.startEditing(n,m);
    3 删除
     删除选定的行
       var r = grid.getSelectionModel().getSelected();
       ds.remove(r);
     删除多行,也一样,用getSelections()反法取到选中的行的一个数组,然后再一一删除。
     删除所有行
       ds.removeAll();     
    4 修改
      两种方法,一种直接手动点击需要修改的单元格,EditorGridPanell中的ClicksToEdit来设置点击几下进入编辑状态。
             还有一种从别处获得数据自动修改。
             假设一条新的数据,
              var nr = ['修改后的例子'];
            选定你要修改的行
              var recordtoedit = grid.getSelectionModel().getSelected();
                       或者var recordtoedit = ds.getAt(rowIndex);
               recordtoedit.set('test','修改后的例子');
      还可以在修改完毕后将修改过的行的颜色改变来标示出哪一条是修改过的。
          添加事件
            grid.on('afteredit',function(e){
                       var rowIndex = e.row;
                       grid.getView().getRow(rowIndex).style.backgroundColor="red";
                        //可以增加透明度效果  
                       grid.getView().getRow(number).style.filter = "alpha(opacity=50)";
                       grid.getView().getRow(number).style.MozOpacity =".5";
            });
        
原文出处:http://hi.baidu.com/mousetrapj/blog/item/4e58d501ead2c807728da546.html/cmtid/f1f0aa5c11b06946faf2c00c

Ext之ExtGrid增删改查询回顾总结的更多相关文章

  1. NHibernate系列文章三:简单的增删改查询

    摘要 上一篇文章只完成了简单的NHibernate安装.配置和连接数据库.这篇文章介绍怎样实现最简单的数据库读写操作. 1. 重构ISessionFactory生成过程 将生成ISessionFact ...

  2. ORM增删改查询例题

    public partial class Form1 : Form     {         private MydbInfoDataContext context = new MydbInfoDa ...

  3. MySQL数据库学习笔记(九)----JDBC的ResultSet接口(查询操作)、PreparedStatement接口重构增删改查(含SQL注入的解释)

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  4. python 全栈开发,Day62(外键的变种(三种关系),数据的增删改,单表查询,多表查询)

    一.外键的变种(三种关系) 本节重点: 如何找出两张表之间的关系 表的三种关系 一.介绍 因为有foreign key的约束,使得两张表形成了三种了关系: 多对一 多对多 一对一 二.重点理解如果找出 ...

  5. PHP-----练习-------租房子-----增删改查,多条件查询

    练习-------租房子-----增删改查,多条件 一 .题目要求: 二 .做法: [1]建立数据库 [2]封装类文件------DBDA.class.php <?php class DBDA ...

  6. SpringMVC整合Hibernate实现增删改查之按条件查询

    首先我贴出我项目的结构,只完成了条件查询的相关代码,增删改没有写. 1.新建一个动态Web工程,导入相应jar包,编写web.xml配置文件 <context-param> <par ...

  7. Elasticsearch增删改查 之 —— mget多文档查询

    之前说过了针对单一文档的增删改查,基本也算是达到了一个基本数据库的功能.本篇主要描述的是多文档的查询,通过这个查询语法,可以根据多个文档的查询条件,返回多个文档集合. 更多内容可以参考我整理的ELK文 ...

  8. OracleHelper(对增删改查分页查询操作进行了面向对象的封装,对批量增删改操作的事务封装)

    公司的一个新项目使用ASP.NET MVC开发,经理让我写个OracleHelper,我从网上找了一个比较全的OracleHelper类,缺点是查询的时候返回DataSet,数据增删改要写很多代码(当 ...

  9. 夺命雷公狗---Thinkphp----12之文章的增删改查(图片上传和关联查询)

    我们由于表分析的不够完善,所以我们来加多一个tid的字段,到时候主要目的是为了更好的遍历出文章是属于那个分类下的,表如下所示: 那么下一步我们就开始创建一个ArticleController.clas ...

随机推荐

  1. Chrome 及其 插件“个性化设置”备份

    Chrome版本发布时间表 2016.10.13 v54.0.2840.59  主题颜色由 蓝色 变为 灰色 2016.11.17 重新使用 Chrome 浏览器(v54.0.2840.99),并设置 ...

  2. HDU 3333 | Codeforces 703D 树状数组、离散化

    HDU 3333:http://acm.hdu.edu.cn/showproblem.php?pid=3333 这两个题是类似的,都是离线处理查询,对每次查询的区间的右端点进行排序.这里我们需要离散化 ...

  3. 介绍一个非常好用的跨平台C++开源框架:openFrameworks

    介绍一个非常好用的跨平台C++开源框架:openFrameworks 简介 首先需要说明的一点是: openFrameworks 设计的初衷不是为计算机专业人士准备的, 而是为艺术专业人士准备的, 就 ...

  4. JS 对数组的常用处理

    首先写游戏的时候,JSON字符串转成OBJECT的时候,希望做个数组随机排序的方法如下: //用Math.random()函数生成0~1之间的随机数与0.5比较,返回-1或1 function ran ...

  5. poj 3264(线段树)

    http://poj.org/problem?id=3264 初学线段可以做的水题,也是线段树的基础运用.也是我的第一个线段树的题. 题意:在区间范围内的最大值减去最小值 思路:线段树记录下每个区间内 ...

  6. Frame创建窗体实例

    public class Test { public static void main(String[] args) { // TODO Auto-generated method stub Fram ...

  7. iOS On-Demand Resources简单理解

    ios9引入了一个新功能,On-Demand Resources,它是app thinning 的一部分.这个机能简单的说,就是在下载app的时候,app中包含的不重要资源不下载,等到需要时,在由系统 ...

  8. Sublime Text永久设置使用4个空格缩进

    Sublime Text是一款轻量高效的代码编辑器,官网地址是:http://www.sublimetext.com/,默认情况下sublime是使用tab进行缩进,如果手动敲空格是比较麻烦的,并且很 ...

  9. 【转】Android Studio系列教程六--Gradle多渠道打包

    原文链接:http://stormzhang.com/devtools/2015/01/15/android-studio-tutorial6/ 由于国内Android市场众多渠道,为了统计每个渠道的 ...

  10. VS:101 Visual Studio 2010 Tips

    101 Visual Studio 2010 Tips Tip #1        How to not accidentally copy a blank line TO – Text Editor ...