学习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. sql 查询

    select * from (select * ,row_number() over(partition by CreateUID order by asid)num from AuctionSell ...

  2. ASP.NET 对于文件的下载与上传

    /// <summary> /// 下载附件查看 /// </summary> /// <param name="sender"></pa ...

  3. PhpStorm 9.03 集成 开源中国(oschina.net)的Git项目,提交SVN时注意事项

    第一步:配置 git.exe File -> Default Settings -> Version Control -> Git -> Path go Git executa ...

  4. 【荐】PHP操作MongoDB GridFS 存储文件,如图片文件

    GridFS是MongoDB的一个内置功能,它提供一组文件操作的API以利用MongoDB存储文件,GridFS的基本原理是将文件保存在两个Collection中,一个保存文件索引,一个保存文件内容, ...

  5. C和指针 第十章 结构和联合 (一)

    结构体: 聚合数据类型是指,能够同时存储超过一个的单独数据,C语言中有两个聚合数据类型,数组和结构体.数组中储存的类型必须相同,元素通过下标和指针引用来访问的. 结构体也是一些值的集合,但是结构体中每 ...

  6. Android模拟位置信息

    Android模拟位置程序,俗称GPS欺骗,只能修改采用GPS定位的软件. 手机定位方式目前有4种:基站定位,WIFI定位,GPS定位,AGPS定位 常见的修改手法: 1. 抓包欺骗法,抓包改包欺骗服 ...

  7. PHP PHPUnit的简单使用

    1.window安装pear的教程:http://jingyan.baidu.com/article/ca41422fd8cf3d1eae99ed3e.html 2.在工作目录下,放两个文件: 1)C ...

  8. java12

    1:List的子类(掌握) (1)List的子类特点 ArrayList: 底层数据结构是数组,查询快,增删慢 线程不安全,效率高 Vector: 底层数据结构是数组,查询快,增删慢 线程安全,效率低 ...

  9. Select标签下拉列表二级联动级联

    首先从服务器端,绑定下拉列表,二级下拉的text命名按照一定规则加上一级下拉的ID. var options=new Array(); $(document).ready(function(){ // ...

  10. jquery中使用serialize() 序列化表单时 中文乱码问题

    序列化中文时之所以乱码是因为.serialize()调用了encodeURLComponent方法将数据编码了 解决方法就是进行解码 1 原因:.serialize()自动调用了encodeURICo ...