今天在用datagrid时偶然发现一个小问题,问题如下:
在使用getSelections这个方法时,不管我选择几行内容返回的值总是1行数据,于是跟踪了一下easyui的源码,
发现第3行if(opt.idField)的值有关,因为我设置了idField属性,所以永远不会走else部分,得不到的当前选择的行
补充说明下,我用的是jQuery EasyUI 1.2.6测试的,而同样jQuery EasyUI 1.2.2的这段代码并不是这么写的
[color=red][size=medium]
[b]更新: :D
问题已解决,原来是这样的:我的idField值为'id',而我现在载入的数据中并没有id属性,所以它会自动认为所有id是一样的,所有的行数据都是相同的,于是得出的结果总是1行;而我在把idField去掉之后,自然就能够得出正确的结果,所以上述的代码还是有点误导了我。[/b][/size][/color]
在使用getSelections这个方法时,不管我选择几行内容返回的值总是1行数据,于是跟踪了一下easyui的源码,
var opts=$.data(_48a,"datagrid").options;
var data=$.data(_48a,"datagrid").data;
if(opts.idField){
return $.data(_48a,"datagrid").selectedRows;
}else{
var rows=[];
opts.finder.getTr(_48a,"","selected",2).each(function(){
var _48b=parseInt($(this).attr("datagrid-row-index"));
rows.push(data.rows[_48b]);
});
return rows;
}
发现第3行if(opt.idField)的值有关,因为我设置了idField属性,所以永远不会走else部分,得不到的当前选择的行
补充说明下,我用的是jQuery EasyUI 1.2.6测试的,而同样jQuery EasyUI 1.2.2的这段代码并不是这么写的
[color=red][size=medium]
[b]更新: :D
问题已解决,原来是这样的:我的idField值为'id',而我现在载入的数据中并没有id属性,所以它会自动认为所有id是一样的,所有的行数据都是相同的,于是得出的结果总是1行;而我在把idField去掉之后,自然就能够得出正确的结果,所以上述的代码还是有点误导了我。[/b][/size][/color]