ext grid 动态列

Alice 2010-10-11 04:19:55
js代码:
Ext.onReady(function() {
//声明函数变量
var data;
//动态添加列,这是关键代码
var addColumn = function()
{
this.fields = '';
this.columns = '';
this.addColumns=function(name,caption)
{
if(this.fields.length > 0)
{
this.fields += ',';
}
if(this.columns.length > 0)
{
this.columns += ',';
}
this.fields += '{name:"' + name + '"}';
this.columns += '{header:"' + caption + '",dataIndex:"' + name + '",width:80,sortable:true}';
};
};
//从服务器端获取列,然后动态添加到ColumnModel中
Ext.Ajax.request
({
url:"getHJTJYLB.asp",
success:function(response)
{
if(response.responseText=="")
{
return;
}
data = new addColumn();
var res = Ext.util.JSON.decode(response.responseText);//这句话不太明白具体返回的格式
for(var i=0;i<res.length;i++)
{
for(var p in res[i])
{
data.addColumns(p,p);
}
}
//动态生成GridPanel
makeGrid();
},
failure:function()
{
Ext.Msg.alert("消息","查询出错---->请打开数据库查看数据表名字是否正确");
}
});
//动态生成GridPanel
var makeGrid = function()
{
var cm = new Ext.grid.ColumnModel(eval('([' + data.columns + '])'));
//new Ext.grid.RowNumberer; // 自动显示行号
cm.defaultSortable = true;
var fields = eval('([' + data.fields + '])');
var newStore = new Ext.data.Store
({
proxy:new Ext.data.HttpProxy({url:"getHJTJYLB.asp"}),
reader:new Ext.data.JsonReader({totalProperty:"totalPorperty",root:"root",fields:fields})
});

newStore.load();

var gridPanel = new Ext.grid.GridPanel
({

align : 'center',
width : Ext.get("UserBody").getWidth(),
height : Ext.get("UserBody").getHeight() - 100,
cm : cm,
store : store,
region : 'center',
margins : '0 5 5 5',
frame : true, // 表格外加边框
columnLines : true,
clicksToEdit : 1,
trackMouseOver : false,
// padding:"10px",
/*viewConfig : {
forceFit : true
},*/
enableHdMenu : false
});
};


});
***********************************************

js 代码其中的var res = Ext.util.JSON.decode(response.responseText);
这句话要怎么样格式返回来,不太清楚

后台的代码要怎么样写,以下我写的,但是觉得不太清楚,这样写对不对,还需要指点一下
public String getDYnamicColName(String szAdmDeptID,String szDeptLevel) throws Exception
{
Connection DBConn = null;
ConnPool cp = null;
String Json="";
try
{
cp = new ConnPool();
DBConn = cp.getConnection();
if (DBConn == null)
{
System.out.println("Failed in getting Connection!");
return null;
}
String sql = "select row_number() over(order by deptid ) as rm,deptname from jnhb_dept where admdeptid='10001' and deptlevel='3' ";
Statement statement = DBConn.createStatement();
statement.execute(sql);
ResultSet rs = statement.getResultSet();

JSONObject str=new JSONObject();
str.put("totalCount","1");

while(rs.next())
{
JSONArray columns = new JSONArray();
JSONObject columnsStr=new JSONObject();
columnsStr.put("header", rs.getString("deptname"));
columnsStr.put("dataIndex",rs.getInt("rs"));
columnsStr.put("width",80);
columnsStr.put("sortable","true");
columns.add(columnsStr);
str.put("columns",columns);

JSONArray fields = new JSONArray();
JSONObject fieldsStr=new JSONObject();
fieldsStr.put("name", rs.getInt("rs"));
fields.add(fieldsStr);
str.put("fields",fields);
}
rs.close();
statement.close();
return(Json);
}
catch (Exception e)
{
zqLog.writeDebug("Failed in JN_NYXHAction.getDataInfo!");
e.printStackTrace();
return (null);
}
finally
{
if (DBConn != null) cp.closeConnection();
}
}

...全文
746 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
Alice 2010-10-20
  • 打赏
  • 举报
回复
自己顶一下~~~~~~~~~~~~~~
Alice 2010-10-13
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 aj3423 的回复:]
grid 动态列有现成的方法,在store.load 时候,后台返回东西里多带一个metaData就ok,
api 的JsonReader 上有例子,


JScript code
{
metaData: { // 就是加这个 metaData
"root": "rows",
"fields": [
{"name":……
[/Quote]

能再说得细点吗,我不太明白哦,我太笨了
Alice 2010-10-13
  • 打赏
  • 举报
回复
能不能给点具体的例子呀?

困惑中..............
hoojo 2010-10-12
  • 打赏
  • 举报
回复
可以照楼上的试试,关于动态列网上也有写好的插件可以用。lz可以搜搜
不过可以从后动态直接得到列头信息,用Ext.decode(后台返回列信息);转换从后js对象
添加到grid的columns数组中
aj3423 2010-10-11
  • 打赏
  • 举报
回复
grid 动态列有现成的方法,在store.load 时候,后台返回东西里多带一个metaData就ok,
api 的JsonReader 上有例子,

{
metaData: { // 就是加这个 metaData
"root": "rows",
"fields": [
{"name": "name"},
{"name": "job"}
]
},
...
colModel: ....// 这里加上这个,在store.on('metachange' 时候用到
// Reader's configured root
// (this data simulates 2 results per page)
"rows": [ // *Note: this must be an Array
{ "id": 1, "name": "Bill", "occupation": "Gardener" },
{ "id": 2, "name": "Ben", "occupation": "Horticulturalist" }
]
}


然后给store注册metachange事件
grid.store.addListener('metachange', function(store, meta){
var cm = grid.getColumnModel();
cm.setConfig(meta.colModel);
grid.reconfigure(store, cm);
},this);
Re: 《 Linux磁盘与文件系统管理命令 》   ---------------------------------------内容提要: 01/16)命令fdisk           :磁盘分区工具02/16)命令partprobe  :更新内核的硬盘分区表信息(即分区即刻生效)03/16)命令 tune2fs     :调整 ext2/ext3/ext4 文件系统参数04/16)命令 parted       :磁盘分区工具(大小通吃)05/16)命令 mkfs          :创建Linux文件系统06/16)命令 dumpe2fs :导出ext2/ext3/ext4文件系统信息07/16)命令 resize2fs   :调整ext2/ext3/ext4文件系统大小08/16)命令 fsck           :检查并修复Linux文件系统09/16)命令 dd             :转换或复制文件10/16)命令 mount       :挂载文件系统11/16)命令 umount     :卸载文件系统12/16)命令 df              :报告文件系统磁盘空间的使用情况13/16)命令 mkswap    :创建交换分区14/16)命令 swapon     :激活交换分区15/16)命令 swapoff     :关闭交换分区16/16)命令 sync           :刷新文件系统缓冲区17/17)附录                   :NFS 网络文件服务器到安装;客户端的挂载 -t nfs;及新分区的权限测试  本人在教学和实战过程中发现,即便是有一定运维经验的人,可能已经能够搭建一定复杂度的Linux架构,但是在来来回回的具体操作中,还是体现出CLI(命令界面)功底不够扎实,甚至操作的非常‘拙’、处处露‘怯’。 对一个士兵来说,枪就是他的武器,对于一个程序员来说,各种library(工具库)就是他的武器;而对于Linux运维人员来说,无疑命令行工具CLI(命令界面)就是他们的武器;高手和小白之间的差距往往就体现在对于这些“武器”的掌握和熟练程度上。有时候一个参数就能够解决的事情,小白们可能要写一个复杂的Shell脚本才能搞定,这就是对CLI(命令界面)没有理解参悟透彻导致。 研磨每一个命令就是擦拭手中的作战武器,平时不保养不理解,等到作战的时候,一定不能够将手中的武器发挥到最好,所以我们要平心、静气和专注,甘坐冷板凳一段时间,才能练就一身非凡的内功! 本教程从实战出发,结合当下流行或最新的Linux(v6/7/8 版本)同时演示,将命令行结合到解决企业实战问题中来,体现出教学注重实战的务实精神,希望从事或未来从事运维的同学,能够认真仔细的学完Linux核心命令的整套课程。 本课程系将逐步推出,看看我教学的进度和您学习的步伐,孰占鳌头! 注:关于教学环境搭建,可以参考本人其它课程系,本教学中就不再赘述! 《参透 VMware 桌面级虚拟化》 《在虚拟机中安装模版机(包括应用软件等)》 《SecureCRT 连接 GNS3/Linux 的安全精密工具》 
Ext grid中渲染进度条,超帅 源码-----下载不扣分,回帖加1分,欢迎下载,童叟无欺。Ext grid中渲染进度条,超帅 源码-----下载不扣分,回帖加1分,欢迎下载,童叟无欺。Ext grid中渲染进度条,超帅 源码-----下载不扣分,回帖加1分,欢迎下载,童叟无欺。Ext grid中渲染进度条,超帅 源码-----下载不扣分,回帖加1分,欢迎下载,童叟无欺。Ext grid中渲染进度条,超帅 源码-----下载不扣分,回帖加1分,欢迎下载,童叟无欺。Ext grid中渲染进度条,超帅 源码-----下载不扣分,回帖加1分,欢迎下载,童叟无欺。Ext grid中渲染进度条,超帅 源码-----下载不扣分,回帖加1分,欢迎下载,童叟无欺。Ext grid中渲染进度条,超帅 源码-----下载不扣分,回帖加1分,欢迎下载,童叟无欺。Ext grid中渲染进度条,超帅 源码-----下载不扣分,回帖加1分,欢迎下载,童叟无欺。Ext grid中渲染进度条,超帅 源码-----下载不扣分,回帖加1分,欢迎下载,童叟无欺。Ext grid中渲染进度条,超帅 源码-----下载不扣分,回帖加1分,欢迎下载,童叟无欺。Ext grid中渲染进度条,超帅 源码-----下载不扣分,回帖加1分,欢迎下载,童叟无欺。Ext grid中渲染进度条,超帅 源码-----下载不扣分,回帖加1分,欢迎下载,童叟无欺。Ext grid中渲染进度条,超帅 源码-----下载不扣分,回帖加1分,欢迎下载,童叟无欺。

52,797

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 Ajax
社区管理员
  • Ajax
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧