- 浏览: 2631373 次
- 性别:
- 来自: 小胖儿的大城
-
文章分类
最新评论
-
ni4wangba0:
ni4wangba0 写道亲测,算法有问题。对不起,其实是我自 ...
谈谈"求线段交点"的几种算法(js实现,完整版) -
ni4wangba0:
亲测,算法有问题。
谈谈"求线段交点"的几种算法(js实现,完整版) -
kers007:
苹果不让Webapp 在appstore 里发布,我不知道对 ...
苹果真的要在 AppStore 里封杀 WebApp 吗? -
striveandlive:
fins = js大牛
[原创]GT-Template, 一个超轻量级的js模板工具. -
AlwaysYang:
基础扎实的才能行走天下。
关于body的"大小"在ie和ff下的一些基础知识
GT-Grid 1.0 基础教程(二)
教程说明:
这是一个告诉大家如何快速的利用GT-Grid开发列表的基础教程.以后会推出"高级教程".
查看其他教程,以及最新版本信息,请点击这里
第二章: 让"纯客户端只读列表"变得更强大一些吧
让我们继续来完善和加强上一章中做出的那个列表吧.
在开始之前,为了保留我们之前的成果,不至于学习的过程中把前一个成果弄坏, 我们将"mydemo1.html"另存为"mydemo2.html".
OK,开始.
=========================================
1 扩展数据列
示例中的数据(学生的信息) , 由6列构成 : 学号 , 姓名 , 年龄 , 性别, 英语成绩, 数学成绩.
这是我们能拿到的原始信息.
但是有时候,我们往往需要在页面中扩展出新的信息, 这些信息并不在原始信息内.
例如 我希望列表中包含 "总成绩"一列. 这时候,"总成绩"对应的数据就必须在页面内生成.
我们将这种并不存在于原始数据中,但是希望扩充到原始数据中的列叫做"扩展数据列".
在GT-Grid中, 利用数据集列 (dataset的field) 的initValue方法就可以实现.
按下面的方式修改代码.
initValue 属性指向一个函数, 该函数的返回值, 就为record的该列数据.
上例中, 会创建一个叫total的"扩展列" , 它会使每一条record的 total 属性值为 1.即 :
record['total']=1;
然后,我们就可以在 columns的定义中加入一个column,让其显示 total列 (此时total就和普通的数据列是一样的).
运行看一下效果, 你会发现,列表变成了7列, 所有记录的第7列"总成绩"值都为1.
为1 肯定不是我们想要的结果, 我们需要的是 计算 英语成绩与数学成绩的总和.
我们来改造一下 initValue 函数. initValue 函数的第一个参数为"对数据集进行迭代时的,当前record".
那么我们只要从record中取出 english 和 math成绩 相加即可.
另外, 现在列多了, 看起来不方便, 我们可以通过调整列宽来 美化外观. 通过给各个column设置"width"属性来实现.
目前版本的 GT-Grid的列宽只支持整数(单位:像素) 不支持百分比.
我们将7列的宽度 依次调整为 : 50 , 100 ,50, 50 ,60 ,60 ,70 .
这时候也许大家会发现, 分数相关的列都是内容左对齐, 这个似乎不符合国际关联, 通常数字都是右对齐的.
那么我们也改一下吧. 很简单, 通过给column设置"align"属性来实现.
align : 水平方向上 内容的对齐方式, 可选值: left(默认) center right.
运行一下看看结果吧
.
=========================================
2 扩展显示列
除了前面提到的"扩展数据列" ,还有一种扩展列, 它和"数据"本身关系不大,他更主要的作用是用来显示一些数据以外的东西.
举个例子. 我们肯定常常简单这样的列表:
前面使一些数据,最后一个单元格里有一个按钮或者是图片 或者是链接, 点击后可以执行一些特殊的操作.
那么这时候, 这最后一列就不能叫做 扩展数据列了, 它更多的职责时"显示", 它通常不会参与到 排序 统计 运算 等数据操作中.
这样的扩展列, 我们叫做"扩展显示列".
在GT-Grid中, 利用column 的 renderer 方法就可以实现.
对示例中的 column定义做如下修改 :
我们加入了一列"详细信息".
column.renderer 函数的返回值 是一个合法的html字符串. 这个返回值将显示在表格的相应单元格内.
renderer 函数的 6个参数依次为
此例中,暂时我们只需要一个record就可以了. 我们根据record信息,拼装出了一个链接.(当然在这个演示中链接的地址是无效的)
再次运行吧.
=========================================
其实 很多 扩展数据列的功能 ,通过扩展显示列 也可以实现.
例如关于 total 列的 , 我们也可以只在columns中扩展显示列, 直接使用:
renderer : function(...) { return 数学+英语 ; }
那么该如何选择呢?? 一个简单的原则如下:
如果你扩展的列 只是用来显示给用户看 , 而不会参与到 编辑 排序 统计 运算 等数据操作中,
那么使用扩展显示列就可以, 否则就应该使用扩展数据列.
(GT-Grid 考虑的真是周全啊 哈哈哈)
=========================================
3 个性化渲染列
之前的例子中, 所有数据在显示的时候都是"中规中矩". 这样有时候是无法满足我们的需求的 , 有时候我们也许希望列表显示的更加丰富一些.
例如: 在成绩一列, 我们希望总成绩大于170分的 用红颜色标识出来(因为这是一个很不错的成绩), 而120分以下的用蓝色标识出来(成绩很差).
这个需求怎么实现呢? 我想从上面加连接的例子 里大家应该能够悟出来 ,是的 没错, 继续使用 renderer .
大家直接看代码, 应该很容易就明白怎样做 以及为什么这样做.
对本小节做个简单概括: 我们利用renderer返回html的特性, 利用html代码对原始数据进行包装,便可以实现显示效果的自定(个性化渲染列).
=========================================
4 数据值 与 显示值的映射
本例中, 大家看到了, 性别一列一值 显示的时M/F, 这并不是我们希望看到的.
有了前两节的基础, 我想大家都可以 利用 renderer 方法轻易的实现 将M/F变成男/女.
在这小节我要告诉大家的是, 这种简单的映射, GT-Grid提供了一个工具函数, 可以帮助大家更简单的完成这个工作.
GT.Grid.mappingRenderer函数有两个参数:
第一个是用来做映射的json-object, 第二个是数据不满足映射关系时 希望返回的值.
用来做映射的json-object就相当于一个可 key-value的hashmap, key就是列对应的数据的值, value就是希望映射成的值.
这个还是很好理解的.
当数据的值不在 这个关于性别的 映射关系中时, 将返回 '未知'.
=========================================
这一章讲解了 对列的扩展和显示效果的自定义, 只要你合理的利用 initValue 以及 renderer ,绝对可以创造出丰富多彩的列表.
好了 ,第二章到此结束了. 已经很晚了, 明天再写吧. 下一章再见
.
=========================================
最后的成果图:
问个问题,grid 的columns 表头上面加 个按钮 怎么做呢? 比如 表头 “性别”为一个按钮 点击有触发事件,或者不做成按钮,点击“性别”就有触发事件
column 有 hdRenderer 方法
在这个方法里 返回一段 html代码就可以了
hdRenderer 方法 下一版将改名叫 headRenderer
var data1 = [ { no : 1 , name :'aaa', age : 12, gender : 'M' , english : 76.5 , chinese : 50, math :92 ,physic: 100}, { no : 2 , name :'bbb', age : 11, gender : 'F' , english : 89 , chinese : 50, math :87 ,physic: 100}, { no : 3 , name :'ccc', age : 13, gender : 'F' , english : 53 ,chinese : 50, math :62 ,physic: 100} ]; var dsConfig= { data : data1 , fields :[ {name : 'no' , type: 'int' }, {name : 'name' }, {name : 'age' , type: 'int' }, {name : 'gender' }, {name : 'english', type: 'float' }, {name : 'Chinese', type: 'float' }, {name : 'total1' , type: 'float', initValue : function(record){return record['english']+record['chinese'];}}, {name : 'math' , type: 'float' }, {name : 'physic', type: 'float' }, {name : 'total2' , type: 'float', initValue : function(record){return record['math']+record['physic'];}} ] }; var colsConfig = [ { id : 'no' , header : "学好" ,width : 50}, { id : 'name' , header : "你好" ,width:100}, { id : 'age' , header : "年龄" ,width:50}, { id : 'gender' , header : "性别" ,width:50, renderer : GT.Grid.mappingRenderer( { 'M':'男', 'F':'女'} , '未知' ) }, { id : 'english' , header : "英语" ,width:60}, { id : 'Chinese' , header : "语文" ,width:60}, { id : 'total1' , header : "文科总成绩" ,width:70 } { id : 'math' , header : "数学" ,width:60, align :'right'}, { id : 'physic' , header : "物理" ,width:60, align :'right'}, { id : 'total2' , header : "理科总成绩" ,width:70 } } ]; 提示找不到'total1'和'total2'列,请问fins,这个怎么解决?
这个是什么原因??
教程说明:
这是一个告诉大家如何快速的利用GT-Grid开发列表的基础教程.以后会推出"高级教程".
查看其他教程,以及最新版本信息,请点击这里
第二章: 让"纯客户端只读列表"变得更强大一些吧
让我们继续来完善和加强上一章中做出的那个列表吧.
在开始之前,为了保留我们之前的成果,不至于学习的过程中把前一个成果弄坏, 我们将"mydemo1.html"另存为"mydemo2.html".
OK,开始.
=========================================
1 扩展数据列
示例中的数据(学生的信息) , 由6列构成 : 学号 , 姓名 , 年龄 , 性别, 英语成绩, 数学成绩.
这是我们能拿到的原始信息.
但是有时候,我们往往需要在页面中扩展出新的信息, 这些信息并不在原始信息内.
例如 我希望列表中包含 "总成绩"一列. 这时候,"总成绩"对应的数据就必须在页面内生成.
我们将这种并不存在于原始数据中,但是希望扩充到原始数据中的列叫做"扩展数据列".
在GT-Grid中, 利用数据集列 (dataset的field) 的initValue方法就可以实现.
按下面的方式修改代码.
var dsConfig= { data : data1 , fields :[ /* ...其他field略 ... */ {name : 'total' , type: 'float', initValue : function(record){ return 1; } } ] };
initValue 属性指向一个函数, 该函数的返回值, 就为record的该列数据.
上例中, 会创建一个叫total的"扩展列" , 它会使每一条record的 total 属性值为 1.即 :
record['total']=1;
然后,我们就可以在 columns的定义中加入一个column,让其显示 total列 (此时total就和普通的数据列是一样的).
var colsConfig = [ /* ...其他column略 ... */ { id : 'total' , header : "总成绩" } ];
运行看一下效果, 你会发现,列表变成了7列, 所有记录的第7列"总成绩"值都为1.
为1 肯定不是我们想要的结果, 我们需要的是 计算 英语成绩与数学成绩的总和.
我们来改造一下 initValue 函数. initValue 函数的第一个参数为"对数据集进行迭代时的,当前record".
那么我们只要从record中取出 english 和 math成绩 相加即可.
{ name : 'total' , type: 'float', initValue : function(record){ return record['english'] + record['math']; } }
另外, 现在列多了, 看起来不方便, 我们可以通过调整列宽来 美化外观. 通过给各个column设置"width"属性来实现.
目前版本的 GT-Grid的列宽只支持整数(单位:像素) 不支持百分比.
我们将7列的宽度 依次调整为 : 50 , 100 ,50, 50 ,60 ,60 ,70 .
这时候也许大家会发现, 分数相关的列都是内容左对齐, 这个似乎不符合国际关联, 通常数字都是右对齐的.
那么我们也改一下吧. 很简单, 通过给column设置"align"属性来实现.
align : 水平方向上 内容的对齐方式, 可选值: left(默认) center right.
var colsConfig = [ /* ...其他column略 ... */ { id : 'english' , header : "英语" , width : 60 , align :'right'} ]
运行一下看看结果吧

=========================================
2 扩展显示列
除了前面提到的"扩展数据列" ,还有一种扩展列, 它和"数据"本身关系不大,他更主要的作用是用来显示一些数据以外的东西.
举个例子. 我们肯定常常简单这样的列表:
前面使一些数据,最后一个单元格里有一个按钮或者是图片 或者是链接, 点击后可以执行一些特殊的操作.
那么这时候, 这最后一列就不能叫做 扩展数据列了, 它更多的职责时"显示", 它通常不会参与到 排序 统计 运算 等数据操作中.
这样的扩展列, 我们叫做"扩展显示列".
在GT-Grid中, 利用column 的 renderer 方法就可以实现.
对示例中的 column定义做如下修改 :
var colsConfig = [ /* ...其他column略 ... */ { id : 'detail' , header : "详细信息" , width : 120, renderer : function(value ,record,columnObj,grid,colNo,rowNo){ return '<a href=".?no='+record['no']+'" >'+ record['name'] +' 的详细信息</a>'; } } ];
我们加入了一列"详细信息".
column.renderer 函数的返回值 是一个合法的html字符串. 这个返回值将显示在表格的相应单元格内.
renderer 函数的 6个参数依次为
value : 相应单元格对应的数据值 (本例中为null, 因为数据集中 根本就没有detail列) record : 迭代中当前的record columnObj : 当前的column对象, grid : 当前的grid对象. colNo : 当前的列号 rowNo : 迭代中当前的行号
此例中,暂时我们只需要一个record就可以了. 我们根据record信息,拼装出了一个链接.(当然在这个演示中链接的地址是无效的)
再次运行吧.
=========================================
其实 很多 扩展数据列的功能 ,通过扩展显示列 也可以实现.
例如关于 total 列的 , 我们也可以只在columns中扩展显示列, 直接使用:
renderer : function(...) { return 数学+英语 ; }
那么该如何选择呢?? 一个简单的原则如下:
如果你扩展的列 只是用来显示给用户看 , 而不会参与到 编辑 排序 统计 运算 等数据操作中,
那么使用扩展显示列就可以, 否则就应该使用扩展数据列.
(GT-Grid 考虑的真是周全啊 哈哈哈)
=========================================
3 个性化渲染列
之前的例子中, 所有数据在显示的时候都是"中规中矩". 这样有时候是无法满足我们的需求的 , 有时候我们也许希望列表显示的更加丰富一些.
例如: 在成绩一列, 我们希望总成绩大于170分的 用红颜色标识出来(因为这是一个很不错的成绩), 而120分以下的用蓝色标识出来(成绩很差).
这个需求怎么实现呢? 我想从上面加连接的例子 里大家应该能够悟出来 ,是的 没错, 继续使用 renderer .
大家直接看代码, 应该很容易就明白怎样做 以及为什么这样做.
var colsConfig = [ /* ...其他column略 ... */ { id : 'total' , header : "总成绩" , width : 70 , align :'right', renderer : function(value ,record,columnObj,grid,colNo,rowNo){ var total = record['total']; if (total>170) { total = '<span style="color:red" >'+ total +'</span>'; }else if (total<120) { total = '<span style="color:blue" >'+ total +'</span>'; } return total; } } ];
对本小节做个简单概括: 我们利用renderer返回html的特性, 利用html代码对原始数据进行包装,便可以实现显示效果的自定(个性化渲染列).
=========================================
4 数据值 与 显示值的映射
本例中, 大家看到了, 性别一列一值 显示的时M/F, 这并不是我们希望看到的.
有了前两节的基础, 我想大家都可以 利用 renderer 方法轻易的实现 将M/F变成男/女.
在这小节我要告诉大家的是, 这种简单的映射, GT-Grid提供了一个工具函数, 可以帮助大家更简单的完成这个工作.
var colsConfig = [ /* ...其他column略 ... */ { id : 'gender' , header : "性别" , width : 50 , renderer : GT.Grid.mappingRenderer( {'U': '未知' , 'M':'男', 'F':'女'} , '未知' ) } ];
GT.Grid.mappingRenderer函数有两个参数:
第一个是用来做映射的json-object, 第二个是数据不满足映射关系时 希望返回的值.
用来做映射的json-object就相当于一个可 key-value的hashmap, key就是列对应的数据的值, value就是希望映射成的值.
这个还是很好理解的.
当数据的值不在 这个关于性别的 映射关系中时, 将返回 '未知'.
=========================================
这一章讲解了 对列的扩展和显示效果的自定义, 只要你合理的利用 initValue 以及 renderer ,绝对可以创造出丰富多彩的列表.
好了 ,第二章到此结束了. 已经很晚了, 明天再写吧. 下一章再见

=========================================
最后的成果图:

评论
17 楼
zcs_84
2009-02-12
问个问题 如何获得 gt-Grid 所有显示的表格的行或者列Id号呀 或者说如何给表格的Id赋值呀?????
16 楼
fins
2008-12-11
waynero 写道
问个问题,grid 的columns 表头上面加 个按钮 怎么做呢? 比如 表头 “性别”为一个按钮 点击有触发事件,或者不做成按钮,点击“性别”就有触发事件
column 有 hdRenderer 方法
在这个方法里 返回一段 html代码就可以了
hdRenderer 方法 下一版将改名叫 headRenderer
15 楼
waynero
2008-12-10
问个问题,grid 的columns 表头上面加 个按钮 怎么做呢?
比如 表头 “性别”为一个按钮 点击有触发事件,或者不做成按钮,点击“性别”就有触发事件
比如 表头 “性别”为一个按钮 点击有触发事件,或者不做成按钮,点击“性别”就有触发事件
14 楼
qinchy
2008-12-03
乱码问题已经解决。仍然谢谢。
13 楼
qinchy
2008-12-03
请问fins,
我这里运行的时候出现问题,
在ie6里面提示有错误,
=======================
行:35,字符:80,错误:为结束的字符串变量,
而在firefox中能运行,
但是中文显示的是乱码,我的编码方式是utf-8,
请问这是怎么回事,谢谢先。
我这里运行的时候出现问题,
在ie6里面提示有错误,
=======================
行:35,字符:80,错误:为结束的字符串变量,
而在firefox中能运行,
但是中文显示的是乱码,我的编码方式是utf-8,
请问这是怎么回事,谢谢先。
<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> <meta http-equiv="Pragma" content="no-cache" /> <meta http-equiv="Expires" content="-1" /> <meta http-equiv="Cache-Control" content="no-cache" /> <title>GT-Grid 教程示例</title> <link rel="stylesheet" type="text/css" href="./gt_grid.css" /> <script type="text/javascript" src="gt_msg_cn.js"></script> <script type="text/javascript" src="gt_grid_all.js"></script> <script type="text/javascript" > var data1 = [ { no : 1 , name :'aaa', age : 12, gender : 'M' , english : 76.5 , math :92 }, { no : 2 , name :'bbb', age : 11, gender : 'F' , english : 89 , math :87 }, { no : 3 , name :'ccc', age : 13, gender : 'F' , english : 53 , math :62 } ]; var dsConfig= { data : data1, fields :[ {name : 'no' , type: 'int' , index : 'no' }, {name : 'name' , type: 'string' , index : 'name' }, {name : 'age' , type: 'int' , index : 'age' }, {name : 'gender' , type: 'string' , index : 'gender' }, {name : 'english', type: 'float' , index : 'english' }, {name : 'math' , type: 'float' , index : 'math' }, {name : 'total', type: 'float',initValue : function(record){ return record['english'] + record['math']; } } ] }; var colsConfig = [ { id : 'no',header : "学号", fieldName : 'no',width:60,align:'right'}, { id : 'name',header : "姓名", fieldName : 'name'}, { id : 'age',header : "年龄", fieldName : 'age'}, { id : 'gender',header : "性别", fieldName : 'gender', width : 50 , renderer : GT.Grid.mappingRenderer( {'U': '未知' , 'M':'男', 'F':'女'} , '未知' ) }, //mappingRenderer是用来映射转义的,即把u转义为未知,m转义为男 { id : 'english', header : "英语", fieldName : 'english'}, { id : 'math', header : "数学", fieldName : 'math'}, { id : 'total', header : "总成绩",width :70 ,align :'right', renderer : function(value ,record,columnObj,grid,colNo,rowNo){ var total = record['total']; if (total>170) { total = '<span style="color:red" >'+ total +'</span>'; }else if (total<120) { total = '<span style="color:blue" >'+ total +'</span>'; } return total; } }, { id : 'detail' , header : "详细信息" , width : 120, renderer : function(value ,record,columnObj,grid,colNo,rowNo){ return '<a href=".?no='+record['no']+'" >'+ record['name'] +' 的详细信息</a>'; } } ]; var gridConfig={ id : "grid1", dataset : dsConfig , columns : colsConfig , container : 'grid1_container', toolbarPosition : 'bottom', toolbarContent : 'state' }; var mygrid=new GT.Grid( gridConfig ); GT.Utils.onLoad( GT.Grid.render(mygrid) ); </script> </head> <body> <!-- grid的容器. --> <div id="grid1_container" style="width:700px;height:300px"> </div> </body> </html>
12 楼
fins
2008-12-03
forgood :
你使用的是什么版本?
你使用的是什么版本?
11 楼
forgood
2008-12-02
itlieying 写道
var data1 = [ { no : 1 , name :'aaa', age : 12, gender : 'M' , english : 76.5 , chinese : 50, math :92 ,physic: 100}, { no : 2 , name :'bbb', age : 11, gender : 'F' , english : 89 , chinese : 50, math :87 ,physic: 100}, { no : 3 , name :'ccc', age : 13, gender : 'F' , english : 53 ,chinese : 50, math :62 ,physic: 100} ]; var dsConfig= { data : data1 , fields :[ {name : 'no' , type: 'int' }, {name : 'name' }, {name : 'age' , type: 'int' }, {name : 'gender' }, {name : 'english', type: 'float' }, {name : 'Chinese', type: 'float' }, {name : 'total1' , type: 'float', initValue : function(record){return record['english']+record['chinese'];}}, {name : 'math' , type: 'float' }, {name : 'physic', type: 'float' }, {name : 'total2' , type: 'float', initValue : function(record){return record['math']+record['physic'];}} ] }; var colsConfig = [ { id : 'no' , header : "学好" ,width : 50}, { id : 'name' , header : "你好" ,width:100}, { id : 'age' , header : "年龄" ,width:50}, { id : 'gender' , header : "性别" ,width:50, renderer : GT.Grid.mappingRenderer( { 'M':'男', 'F':'女'} , '未知' ) }, { id : 'english' , header : "英语" ,width:60}, { id : 'Chinese' , header : "语文" ,width:60}, { id : 'total1' , header : "文科总成绩" ,width:70 } { id : 'math' , header : "数学" ,width:60, align :'right'}, { id : 'physic' , header : "物理" ,width:60, align :'right'}, { id : 'total2' , header : "理科总成绩" ,width:70 } } ]; 提示找不到'total1'和'total2'列,请问fins,这个怎么解决?
这个是什么原因??
10 楼
fins
2008-09-25
你是什么版本??
9 楼
itlieying
2008-09-25
var data1 = [
{ no : 1 , name :'aaa', age : 12, gender : 'M' , english : 76.5 , chinese : 50, math :92 ,physic: 100},
{ no : 2 , name :'bbb', age : 11, gender : 'F' , english : 89 , chinese : 50, math :87 ,physic: 100},
{ no : 3 , name :'ccc', age : 13, gender : 'F' , english : 53 ,chinese : 50, math :62 ,physic: 100}
];
var dsConfig= {
data : data1 ,
fields :[
{name : 'no' , type: 'int' },
{name : 'name' },
{name : 'age' , type: 'int' },
{name : 'gender' },
{name : 'english', type: 'float' },
{name : 'Chinese', type: 'float' },
{name : 'total1' , type: 'float', initValue : function(record){return record['english']+record['chinese'];}},
{name : 'math' , type: 'float' },
{name : 'physic', type: 'float' },
{name : 'total2' , type: 'float', initValue : function(record){return record['math']+record['physic'];}}
]
};
var colsConfig = [
{ id : 'no' , header : "学好" ,width : 50},
{ id : 'name' , header : "你好" ,width:100},
{ id : 'age' , header : "年龄" ,width:50},
{ id : 'gender' , header : "性别" ,width:50,
renderer : GT.Grid.mappingRenderer( { 'M':'男', 'F':'女'} , '未知' )
},
{ id : 'english' , header : "英语" ,width:60},
{ id : 'Chinese' , header : "语文" ,width:60},
{ id : 'total1' , header : "文科总成绩" ,width:70 }
{ id : 'math' , header : "数学" ,width:60, align :'right'},
{ id : 'physic' , header : "物理" ,width:60, align :'right'},
{ id : 'total2' , header : "理科总成绩" ,width:70 }
}
];
提示找不到'total1'和'total2'列,请问fins,这个怎么解决?
{ no : 1 , name :'aaa', age : 12, gender : 'M' , english : 76.5 , chinese : 50, math :92 ,physic: 100},
{ no : 2 , name :'bbb', age : 11, gender : 'F' , english : 89 , chinese : 50, math :87 ,physic: 100},
{ no : 3 , name :'ccc', age : 13, gender : 'F' , english : 53 ,chinese : 50, math :62 ,physic: 100}
];
var dsConfig= {
data : data1 ,
fields :[
{name : 'no' , type: 'int' },
{name : 'name' },
{name : 'age' , type: 'int' },
{name : 'gender' },
{name : 'english', type: 'float' },
{name : 'Chinese', type: 'float' },
{name : 'total1' , type: 'float', initValue : function(record){return record['english']+record['chinese'];}},
{name : 'math' , type: 'float' },
{name : 'physic', type: 'float' },
{name : 'total2' , type: 'float', initValue : function(record){return record['math']+record['physic'];}}
]
};
var colsConfig = [
{ id : 'no' , header : "学好" ,width : 50},
{ id : 'name' , header : "你好" ,width:100},
{ id : 'age' , header : "年龄" ,width:50},
{ id : 'gender' , header : "性别" ,width:50,
renderer : GT.Grid.mappingRenderer( { 'M':'男', 'F':'女'} , '未知' )
},
{ id : 'english' , header : "英语" ,width:60},
{ id : 'Chinese' , header : "语文" ,width:60},
{ id : 'total1' , header : "文科总成绩" ,width:70 }
{ id : 'math' , header : "数学" ,width:60, align :'right'},
{ id : 'physic' , header : "物理" ,width:60, align :'right'},
{ id : 'total2' , header : "理科总成绩" ,width:70 }
}
];
提示找不到'total1'和'total2'列,请问fins,这个怎么解决?
8 楼
fins
2008-09-16
目前列宽不支持百分比
7 楼
zuiwoxing
2008-09-16
{ id : 'english' , header : "英语" , width : 60 , align :'right'}
其中width : 60 这里可以设置为百分比吗 ?
其中width : 60 这里可以设置为百分比吗 ?
6 楼
fins
2008-08-18
当前版本不支持纵向统计
5 楼
liliang205
2008-08-18
好像没看到列的统计,请问有列的统计吗?也就是全部数据的纵向统计
4 楼
49271743
2008-07-31
学习啦, 学起来也容易
2 楼
ernest100
2008-07-15
麻烦看看,我这里initValue和 align没有生效,看看我哪里有问题。
var data1 = [ { no : 1 , name :'aaa', age : 12, gender : 'M' , english : 76.5 , math :92 }, { no : 2 , name :'bbb', age : 11, gender : 'F' , english : 89 , math :87 }, { no : 3 , name :'ccc', age : 13, gender : 'F' , english : 53 , math :62 } ]; var dsConfig= { data : data1 , fields :[ {name : 'no' , type: 'int' }, {name : 'name' }, {name : 'age' , type: 'int' }, {name : 'gender' }, {name : 'english', type: 'float' }, {name : 'math' , type: 'float' }, {name : 'total' , type: 'float', initValue : function(record){return 1;}} ] }; var colsConfig = [ { id : 'no' , header : "学好" ,width : 50}, { id : 'name' , header : "你好" ,width:100}, { id : 'age' , header : "年龄" ,width:50}, { id : 'gender' , header : "性别" ,width:50, renderer : GT.Grid.mappingRenderer( { 'M':'男', 'F':'女'} , '未知' ) }, { id : 'english' , header : "英语" ,width:60}, { id : 'math' , header : "数学" ,width:60, align :'right'}, { id : 'total' , header : "总成绩" ,width:70, renderer : function(value ,record,columnObj,grid,colNo,rowNo){ var total = record['total']; if (total>70) { total = '<span style="color:red" >'+ total +'</span>'; }else if (total<120) { total = '<span style="color:blue" >'+ total +'</span>'; } return total; } }, { id : 'detail' , header : "详细信息" , width : 120, renderer : function(value ,record,columnObj,grid,colNo,rowNo){ return '<a href=".?no='+record['no']+'" >'+ record['name'] +' 的详细信息</a>'; } } ]; var gridConfig={ id : "grid1", dataset : dsConfig , columns : colsConfig , container : 'grid1_container', toolbarPosition : 'bottom', toolbarContent : 'state' }; var mygrid=new GT.Grid( gridConfig ); GT.Utils.onLoad( GT.Grid.render(mygrid) );
1 楼
qamer
2008-07-14
太像EXT了,期待接下来的文章
发表评论
-
那些成天说我的GT-Grid抄袭的人注意了
2009-03-19 22:01 10346你们能够在浩瀚的网络中找到 sigmawidgets htt ... -
[发布]GT-Grid 1.42 版 ★& "前后台结合示例"★2009-01-15更新
2009-01-15 02:41 27648=============================== ... -
[发布]GT-Grid 1.36 版 ★& "前后台结合示例"★2008-12-01 12AM 更新
2008-12-01 01:27 10564(最后更新时间 :12月1日 中午12点时, 修正了 1.36 ... -
GT-Grid 近期将会发布一个bug修正版本,然后将会进行较大的重构
2008-11-11 00:12 3912GT-Grid 近期将会发布一个bug修正版本, 主要修正上一 ... -
[发布]GT-Grid 1.25 版 ★& "前后台结合示例" ★2008-10-21 更新
2008-10-21 17:25 20016首先 先道个歉. 之前许诺过 10月20日之前发布,结果迟到了 ... -
对于复杂javabean到json串的转换,建议使用FlexJSON
2008-10-16 11:23 9979gt-grid自带的那个 javaBean与json的转换工具 ... -
[通知] GT-Grid 讨论群 变更
2008-10-10 15:54 3068GT-Grid的群建立至今, 用户早已满员, 每日还有很多申请 ... -
10月中旬支持导出excel和csv的gt-grid会推出
2008-10-04 21:19 272910月中旬支持导出excel和csv的gt-grid会推出 ( ... -
[发布]GT-Grid 1.18版 & "前后台结合示例"更新 ★2008-09-12发布
2008-09-12 16:40 12754这个版本带有 与java后台结合的示例. 单独的最新版本的 ... -
调查: 关于GT-Grid导致IE崩溃的问题
2008-09-09 15:39 4327有网友反应 对GT-Grid进行操作时 会导致IE崩溃. ... -
[发布] GT-Grid 1.15 版 (080908发布) ★
2008-09-08 14:10 4267GT-Grid 1.15版 说明文档. 这篇文档主要说明一些 ... -
[发布] GT-Grid 1.12 版 (080904发布) ★
2008-09-03 11:02 5558GT-Grid 1.12版 说明文档. 这篇文档主要说明一些 ... -
奥运结束, GT启航
2008-08-25 10:11 2954前一阵由于关注奥运 GT做的工作比较少 奥运结束了 GT该再 ... -
最近奥运,GT的开发暂停一段时间,抱歉了
2008-08-18 20:13 19968月8号之后 GT的更新速度缓慢了,我回答问题也没有以前及时了 ... -
[发布] GT-Grid 1.0 奥运版 (080808发布) ★ without doc
2008-08-08 17:17 19570由于文档工作滞后 导致我本来放弃了今天发布的念头 但是还是不忍 ... -
GT-Grid 1.0 基础教程(十二)
2008-08-05 02:06 17561GT-Grid 1.0 基础教程(十二) 教程说明: 这是一 ... -
GT-Grid 1.0 基础教程(十一)
2008-08-03 22:29 8291GT-Grid 1.0 基础教程(十一 ... -
GT-Grid 1.0 基础教程(十)
2008-08-03 00:52 16846GT-Grid 1.0 基础教程(十) 教程说明: 这是一个 ... -
GT-Grid 1.0 基础教程(九)
2008-07-28 00:43 15705GT-Grid 1.0 基础教程(九) 教程说明: 这是一个 ... -
我的两点请求, 麻烦关注GT和ecside的朋友看一下,谢谢了
2008-07-27 21:55 30441 恳请大家以后不要通� ...
相关推荐
本基础教程旨在帮助初学者快速理解并掌握GT-Grid 1.0 的核心概念和基本操作,以便在实际项目中应用。下面将详细阐述GT-Grid 1.0 的关键知识点。 一、GT-Grid 1.0 概述 GT-Grid 1.0 是一个基于Java开发的分布式计算...
### GT-Grid 1.0 基础教程(一)——纯客户端只读列表开发详解 #### 一、教程背景与目标 本教程旨在帮助初学者快速掌握如何使用GT-Grid开发纯客户端只读列表的基本技能。对于那些对Ajax技术下的列表组件不太熟悉的...
市场营销计划书.docx
电缆叉绞机sw18_三维3D设计图纸.zip
(WORD) 土木工程专业毕业设计开题报告 办公楼设计 开题报告.doc
内容概要:本文详细介绍了云南某矿区采用碳捕集与电转气(P2G)技术进行综合能源系统优化调度的研究。通过实例展示了如何利用瓦斯、余热等伴生能源,结合碳捕集和P2G技术,实现了矿区能源系统的高效利用和低碳转型。文中提供了具体的Python代码示例,如瓦斯热值转换、碳捕集与P2G的耦合约束、阶梯式碳机制等,展示了技术细节和优化效果。此外,还讨论了风光消纳率提升、碳交易收益以及系统总成本降低等方面的内容。 适合人群:从事能源系统优化、碳捕集技术和电转气技术研发的专业人士,以及对低碳经济感兴趣的科研人员。 使用场景及目标:适用于希望了解和应用碳捕集与电转气技术进行矿区能源系统优化的企业和技术团队。目标是提高能源利用效率,减少碳排放,降低成本。 其他说明:文章不仅提供了理论模型和算法,还包括了实际项目中的代码实现和优化结果,有助于读者更好地理解和应用相关技术。
卧式长轴切割机sw20可编辑_三维3D设计图纸_三维3D设计图纸.zip
基于单片机protues仿真制作的超高精度电参数测试(仿真图、源代码) 这次设计的课题,智能电参数测试电路是基于单片机,控制外部器件进行操作的。利用protues软件进行局部电路的描绘。然后在使用Keil4软件针对protues仿真部分作出代码控制程序,经过编译,修改调试生成hex文件。最后再把.hex文件加载到protues中ATC80C52单片机芯片系统中,运行硬件仿真电路,做完局部仿真后。最后将部分电路进行模块化处理。最后整合在一块,通过外部中断切换显示各个模块测试的结果数据。 1、单片机仿真; 2、液晶屏或者数码管显示; 3、电流、电压、电阻测量和显示; 4、超高精度电参数测试; 5、仿真图、源代码;
内容概要:本文详细介绍了如何利用西门子1200PLC进行脉冲除尘系统的控制。首先描述了硬件配置,包括PLC主模块、数字量扩展模块以及电磁阀组的连接方式。接着深入探讨了核心控制逻辑的实现,采用SCL语言编写控制程序,实现了分组控制、定时器配置、故障诊断等功能。文中还提供了具体的代码示例,展示了如何通过定时器、脉冲发生器等组件精确控制脉冲阀的工作周期和顺序,确保除尘系统的高效运行。此外,文章分享了一些实际调试过程中遇到的问题及其解决方案,如脉冲宽度设置不当导致的空压机过载、电磁阀内部触点粘连等问题,并提出了相应的预防措施。 适合人群:从事工业自动化领域的工程师和技术人员,特别是熟悉PLC编程和脉冲控制系统的从业者。 使用场景及目标:适用于需要设计和实施高效脉冲除尘控制系统的工厂环境,旨在提高除尘效率,降低能耗,延长设备使用寿命。通过学习本文,读者能够掌握如何使用西门子1200PLC实现复杂的脉冲控制逻辑,解决实际工程中可能遇到的各种问题。 其他说明:文章不仅提供了详细的代码示例,还强调了实际应用中的注意事项和调试技巧,帮助读者更好地理解和应用所学知识。
汽车开关测试台sw23_三维3D设计图纸_三维3D设计图纸.zip
双面锯片磨sw18可编辑_三维3D设计图纸_三维3D设计图纸.zip
模块化除臭生物箱sw18可编辑_三维3D设计图纸_三维3D设计图纸.zip
内容概要:本文介绍了基于矢量延迟锁定环(VDLL)的GPS信号跟踪算法的MATLAB仿真实现。首先,通过生成带有多普勒频移和码相位抖动的GPS中频信号,模拟真实场景。接着,详细阐述了VDLL的核心实现,包括超前即时滞后三路相关、误差计算、状态预测和卡尔曼滤波的应用。文中强调了环路滤波器带宽的自适应调整和动态应力测试的重要性,并展示了仿真结果,证明VDLL在高动态环境下的优越性能。最后,提供了完整的代码包和设计文档,涵盖信号生成、本地信号发生器、相关器组、EKF实现、性能评估和可视化工具等多个模块。 适合人群:从事GPS信号处理、无线通信系统设计的研究人员和技术开发者,尤其是对高动态环境下的信号跟踪感兴趣的工程师。 使用场景及目标:适用于需要提高GPS信号跟踪稳定性和精度的场合,如车载导航、航空导航等领域。目标是通过矢量化处理和动态调整,增强系统的抗干扰能力和跟踪稳定性。 其他说明:文中提到的关键技术和实现细节对于理解和优化GPS信号跟踪算法非常有价值。此外,提供的代码包和设计文档可以作为进一步研究的基础。
数据说明: 该数据集包含8种巴基斯坦芒果的图像2200张。在提出的数据集上进行实验,对收获的芒果进行自动分类和分级,以帮助农民及时交付高质量的芒果供出口,并使用卷积神经网络实现了高准确性。 研究人员和学生可以使用这个数据集来开发、测试和评估不同的计算机视觉算法,为改善农业部门作出贡献。所提供的数据集可被视为测试和比较不同技术水平性能的基准。
时间轮源码
内容概要:本文详细介绍了光伏混合储能系统的虚拟同步发电机(VSG)并网仿真模型。该系统由VSG控制模块、光伏PV模块、蓄电池以及超级电容组成。VSG通过有功-频率环和无功-电压环进行精确控制,确保系统稳定运行。光伏模块采用MPPT扰动观察法跟踪最大功率点,蓄电池提供稳定的恒功率输出,超级电容则用于快速响应瞬态负载变化。文中展示了各个模块的核心代码逻辑及其在仿真环境中的表现,强调了参数整定对系统性能的影响。 适合人群:电力电子工程师、新能源研究人员、仿真建模专家。 使用场景及目标:适用于研究光伏混合储能系统的并网控制策略,优化储能设备的协同工作,提高系统的稳定性和响应速度。目标是通过仿真验证系统在各种工况下的性能,为实际应用提供理论支持和技术指导。 其他说明:文章提供了丰富的代码片段和仿真案例,帮助读者深入理解各模块的工作原理和相互关系。同时,作者分享了许多调试经验和常见错误,有助于新手更快掌握相关技术。
电大土木工程毕业设计施工组织设计_图文.doc
报价单封面建筑土木工程.doc
内容概要:本文详细介绍了如何通过485通讯实现西门子S7-200 SMART PLC与三台台达DT330温控器的通信,并结合昆仑通态触摸屏实现温度监控与设定。主要内容涵盖硬件连接、温控器设置、PLC程序设计(包括初始化、轮询读取温度、中断接收处理、设置温控器温度)、触摸屏设置及常见问题解决方法。文中还特别强调了Modbus RTU轮询机制的应用及其重要性。 适合人群:从事工业自动化控制领域的工程师和技术人员,尤其是那些需要实现PLC与温控器通信的人群。 使用场景及目标:适用于需要精确控制和监测温度的工业环境,如生产车间、实验室等。目标是提供一种稳定可靠的技术方案,确保不同设备间能够高效通信,从而实现精准的温度控制。 其他说明:文中提供的具体代码片段和配置指南有助于读者更好地理解和实施该项目。此外,作者还分享了一些调试过程中遇到的问题及解决方案,帮助读者规避潜在的风险。
安卓app开发学习笔记