表格控件其实也就是帮我们完成了数据的填充工作而已,具体的数据源、要显示的列,列的定制、数据源中的哪条数据显示在哪个列中等属性还是需要我们自己手动配置的,所以我们分下面几步来完成网格控件的数据绑定:

1、定义表格: 定义一个表格比较简单,只需要new几个列即可,带上列的名称和要绑定的数据,定义列代码如:

var cm = new Ext.grid.ColumnModel([  { header: '编号', dataIndex: 'id' },  { header: '性别', dataIndex: 'sex' },  { header: '名称', dataIndex: 'name' },  { header: '描述', dataIndex: 'desc' }  ]);

用header指定列名,用dataIndex指定数据源,也就是字段名。这样一个基本的表格就定义好了。

2、创建数据源:

一般数据源都是以集合的形式存在,这里使用一个2维数组来实现:

var data = [  ['', '男', '张三丰', '是个作家'],  ['', '男', '石曼迪', '会武功'],  ['', '男', '姜子牙', '能捉鬼'],  ['', '女', '穆桂英', '好像是皇帝'],  ['', '男', '孙悟空', '高级程序员']  ];

如果熟悉JS或者PHP的话,对这段代码就不陌生,定义一个数组,这个数组的每一个位置又存储了一个数组。用他来作为静态数据源。

3、解析数据源:

表格创建完毕,数据源也定义完毕,接下来就需要创建他们之间的关系,即配置分组数据集,使用的是创建一个 Ext.data.Store对象,通过它我们可以把任何格式的数据转化成grid可以使用的形式。其中需要告诉他的参数比较多,先看代码,后面解释:

var ds = new Ext.data.Store({  proxy: new Ext.data.MemoryProxy(data),  reader: new Ext.data.ArrayReader({}, [  { name: 'id' }, { name: 'sex' }, { name: 'name' }, { name: 'desc' }  ])  });  ds.load();

proxy:的含义是告诉表格从哪里取数据,可选的方式有HttpProxy、DataProxy、MemoryProxy或ScriptTagProxy。本例我们告诉他从内存中取数据,数据来自名字叫data的数组。

reader:reader告诉我们如何解析这个数据,他可选的方式有Ext.data.ArrayReader,Ext.data.JsonReader。本例使用的是Ext.data.ArrayReader,第一个参数是id (可选项) 下面的行数组内提供了该记录的id(不明白什么意思,试验是有没有都一样),后面参数含义就很明确了,就是刚才创建表格时定义的字段名,他的特点是读取数据比较简单,但是有个缺点就是不支持分页。

最后千万别忘了初始化数据操作调用Store对象的load方法。

4、装配表格

表格的列模型定义好了,原始数据和数据的转换都做好了,剩下的只需要装配在一起,我们的grid就出来了,先上代码,再研究:

var grid = new Ext.grid.GridPanel({  el: 'grid',  ds: ds,  cm: cm,  height:,  width:  });  grid.render();

其实就是实例化一个表格面板控件,用来装表格。第一个参数是指定在哪里显示,这玩意总得在页面的某个部分或位置显示出来,Ext提供了控制div的做法,由于div很灵活,现在网页布局多采用他,所以需要在哪里显示出来,只需要把相应的div的id指定给他即可。下面2个参数很明白,就是我要装载的数据源叫什么,我装载到哪里去等等的。最后也别忘了调用grid.render()方法,让grid开始渲染,就是画界面等等的,这样才能显示出来。

好了,到此为止一个简单的表格控件就完成了,我们来看看完整代码:

  1. <HTML>
  2. <HEAD>
  3. <TITLE>表格</TITLE>
  4. <link rel="stylesheet" type="text/css" href="Ext/resources/css/ext-all.css" />
  5. <script type="text/javascript" src="Ext/ext-base.js"></script>
  6. <script type="text/javascript" src="Ext/ext-all.js"></script>
  7. <script type="text/javascript" src="Ext/ext-lang-zh_CN.js" charset="utf-8"></script>
  8. </HEAD>
  9. <script type="text/javascript">
  10. function GridBasic() {
  11. //1. 定义表格
  12. var cm = new Ext.grid.ColumnModel([
  13. { header: '编号', dataIndex: 'id', sortable: true },
  14. { header: '性别', dataIndex: 'sex' },
  15. { header: '名称', dataIndex: 'name' },
  16. { header: '描述', dataIndex: 'desc' }
  17. ]);
  18. //2. 创建数据源
  19. var data = [
  20. ['1', '男', '张三丰', '是个作家'],
  21. ['2', '男', '石曼迪', '会武功'],
  22. ['3', '男', '姜子牙', '能捉鬼'],
  23. ['4', '女', '穆桂英', '好像是皇帝'],
  24. ['5', '男', '孙悟空', '高级程序员']
  25. ];
  26. //3. 解析数据源
  27. var ds = new Ext.data.Store({
  28. proxy: new Ext.data.MemoryProxy(data),
  29. reader: new Ext.data.ArrayReader({}, [
  30. { name: 'id' }, { name: 'sex' }, { name: 'name' }, { name: 'desc' }
  31. ])
  32. });
  33. ds.load();
  34. //4. 装配表格
  35. var grid = new Ext.grid.GridPanel({
  36. el: 'grid',
  37. ds: ds,
  38. cm: cm,
  39. height:200,
  40. width:500
  41. });
  42. grid.render();
  43. }
  44. Ext.onReady(GridBasic); //开始执行
  45. </script>
  46. <BODY>
  47. <div id="grid"></div>
  48. </BODY>
  49. </HTML>

Ext表格控件的更多相关文章

  1. Ext入门学习系列(五)表格控件(1)

    上节学习了Ext面板控件,为后面的各个控件学习奠定基础,在此基础上本章将学习网络开发最期待的功能——表格控件. 我们都知道网络编程语言中,除了.net其他的基本没有提供网格控件,而最近的asp.net ...

  2. Ext入门学习系列(五)表格控件(3)

    上节学习了Ext中如何绑定服务器端传递的数据.分别用asp.net和asp.net MVC.PHP.XML为例.本节主要介绍绑定之后的分页功能. 一.Ext的表格控件如何绑定? 分页是Ext自带的一个 ...

  3. Ext入门学习系列(五)表格控件(2)

    上节学习了Ext中表格控件,从创建,到定义数据源.绑定显示,大体明白了一个基本的表格控件是怎么实现的.而我们用表格控件多用于从各种数据源接收数据并显示出来,并不是写死的.本章我们就不同数据源的不同实现 ...

  4. 深入浅出ExtJS 第三章 表格控件

    3.1 表格的特性简介 >.Ext中的表格功能:包括排序/缓存/拖动/隐藏某一列/自动显示行号/列汇总/单元格编辑等实用功能; >.表格由类Ext.grid.GridPanel定义,继承自 ...

  5. ExtJS4.2学习(10)分组表格控件--GroupingGrid(转)

    鸣谢网址:http://www.shuyangyang.com.cn/jishuliangongfang/qianduanjishu/2013-11-17/179.html ------------- ...

  6. ExtJS4.2学习(九)属性表格控件PropertyGrid(转)

    鸣谢网址:http://www.shuyangyang.com.cn/jishuliangongfang/qianduanjishu/2013-11-15/178.html ------------- ...

  7. 如何在web中实现类似excel的表格控件

    Execl功能非常强大,内置的很多函数或公式可以大大提高对数据的加工处理能力.那么在web中有没有类似的控件呢?经过一番搜寻,发现handsontable具备了基本的excel功能支持公式,同时能对数 ...

  8. 最好的Angular2表格控件

    现在市面上有大量的JavaScript数据表格控件,包括开源的第三方的和自产自销的.可以说Wijmo的Flexgrid是目前适应Angular 2的最好的表格控件. Angular 2数据表格基本要求 ...

  9. C# DatrgridView表格控件的一些用法

    public class useDatrgrivView { string conn = null; string sqlComm = null; DataSet das = null; DataGr ...

随机推荐

  1. java并发编程实战笔记---(第五章)基础构建模块

    . 5.1同步容器类 1.同步容器类的问题 复合操作,加容器内置锁 2.迭代器与concurrentModificationException 迭代容器用iterator, 迭代过程中,如果有其他线程 ...

  2. 记一次测试环境下PXC集群问题《经验总结》

    1.问题描述                  当PXC集群节点全部宕机的,导致集群几点启动失败.报错导致无法启动   [ERROR] WSREP: It may not be safe to boo ...

  3. ios测试apk

    最近apk在ios上面测试总是会遇到奇奇怪怪的问题,现在是两个项目要集成在一个apk中所以将两个项目运行之后都是编译成了.a文件,然后在两个.a文件中都设置了两个意义相同变量名相同的全局变量(标识当前 ...

  4. centos修改oracle字符集

    1.首先以sysdba的身份登录上去 conn /as sysdba2.关闭数据库shutdown immediate;3.以mount打来数据库,startup mount4.设置session S ...

  5. 【PAT】1010. 一元多项式求导 (25)

    1010. 一元多项式求导 (25) 设计函数求一元多项式的导数.(注:xn(n为整数)的一阶导数为n*xn-1.) 输入格式:以指数递降方式输入多项式非零项系数和指数(绝对值均为不超过1000的整数 ...

  6. day4 递归二分法查找

    现有一个序列,data=[for i in range(1,5000,3)],现在要求看一个数是否在列表中存在,我们知道,我们可以使用in或__contains__()的方法,判断一个值是否在列表中, ...

  7. Vugen 和controller 中的run-time setting区别

    Vugen 和controller 中的run-time setting有什么不同?

  8. bzoj1452 最大流

    很明显最大流.. #include<bits/stdc++.h> #define LL long long #define fi first #define se second #defi ...

  9. SaltStack的配置管理--jinja (七)

    SaltStack的配置管理--jinja 需求场景:使用jinja模板,让各节点的httpd都监听在本机的ip [root@7mini-node1 apache]# vim files/httpd. ...

  10. thinkphp5.0自动加载

    概述 ThinkPHP5.0 真正实现了按需加载,所有类库采用自动加载机制,并且支持类库映射和composer类库的自动加载. 自动加载的实现由think\Loader类库完成,自动加载规范符合PHP ...