我的应用程序用户询问是否可能使包含jqGrid的页面记住网格的筛选、排序和当前页(因为当他们单击网格项执行任务,然后返回时,他们希望它“与他们离开时相同”)。
Cookies 似乎是前进的方式,但如何在页面发出第一个数据请求之前让页面加载这些并设置它们到网格中还在我能力范围之外。
有没有人在使用 jqGrid 进行此类操作方面有经验?谢谢!
我的应用程序用户询问是否可能使包含jqGrid的页面记住网格的筛选、排序和当前页(因为当他们单击网格项执行任务,然后返回时,他们希望它“与他们离开时相同”)。
Cookies 似乎是前进的方式,但如何在页面发出第一个数据请求之前让页面加载这些并设置它们到网格中还在我能力范围之外。
有没有人在使用 jqGrid 进行此类操作方面有经验?谢谢!
问题已解决
最终我使用javascript中的cookie来存储表格的排序列、排序顺序、页码、网格行和筛选条件(使用 JSON/Javascript cookies - 使用prefs
对象)
保存偏好设置
- 从$(window).unload(function(){ ... });
调用
var filters = {
fromDate: $('#fromDateFilter').val(),
toDate: $('#toDateFilter').val(),
customer: $('#customerFilter').val()
};
prefs.data = {
filter: filters,
scol: $('#list').jqGrid('getGridParam', 'sortname'),
sord: $('#list').jqGrid('getGridParam', 'sortorder'),
page: $('#list').jqGrid('getGridParam', 'page'),
rows: $('#list').jqGrid('getGridParam', 'rowNum')
};
prefs.save();
加载偏好设置 - 从 $(document).ready(function(){ ... });
调用
var gridprefs = prefs.load();
$('#fromDateFilter').val(gridprefs.filter.fromDate);
$('#toDateFilter').val(gridprefs.filter.toDate);
$('#customerFilter').val(gridprefs.filter.customer);
$('#list').jqGrid('setGridParam', {
sortname: gridprefs.scol,
sortorder: gridprefs.sord,
page: gridprefs.page,
rowNum: gridprefs.rows
});
// filterGrid method loads the jqGrid postdata with search criteria and re-requests its data
filterGrid();
jqGrid参考文档:http://www.secondpersonplural.ca/jqgriddocs/_2eb0fi5wo.htm
按众所要求 - FILTERGRID代码
function filterGrid() {
var fields = "";
var dateFrom = $('#dateFrom').val();
var dateTo = $('#dateTo').val();
if (dateFrom != "") fields += (fields.length == 0 ? "" : ",") + createField("shipmentDate", "ge", dateFrom);
if (dateTo != "") fields += (fields.length == 0 ? "" : ",") + createField("shipmentDate", "le", dateTo);
var filters = '"{\"groupOp\":\"AND\",\"rules\":[' + fields + ']}"';
if (fields.length == 0) {
$("#list").jqGrid('setGridParam', { search: false, postData: { "filters": ""} }).trigger("reloadGrid");
} else {
$("#list").jqGrid('setGridParam', { search: true, postData: { "filters": filters} }).trigger("reloadGrid");
}
}
function createField(name, op, data) {
var field = '{\"field\":\"' + name + '\",\"op\":\"' + op + '\",\"data\":\"' + data + '\"}';
return field;
}
(function($){
$.jgrid.extend({
getColumnOrder : function ()
{
var $grid = $(this);
var colModel = $grid[0].p.colModel;
var names = [];
$.each(colModel, function(i,n){
var name = this.name;
if (name != "" && name != 'subgrid')
names[names.length] = name;
});
return names;
//return JSON.stringify(names);
//$('#dbgout').val(j);
},
setColumnOrder : function (new_order)
{
var $grid = $(this);
//var new_order = JSON.parse($('#dbgout').val());
//new_order = ['a', 'c', 'd', 'b', 'e'];
// 0 1 2 3 4
var new_order_index = {};
$.each(new_order, function(i,n){
new_order_index[n] = i;
});
//new_order = ['a', 'c', 'd', 'b', 'e'];
// 0 1 2 3 4
// new_order_index a=>0 c=>1 d=>2 b=>3 e=>4
var colModel = $grid[0].p.colModel;
cur = [];
$.each(colModel, function(i,n){
var name = this.name;
if (name != "" && name != 'subgrid')
cur[cur.length] = name;
});
//cur = ['a', 'b', 'c', 'd', 'e'];
// 0 1 2 3 4
cur_index = {};
$.each(cur, function(i,n){
cur_index[n] = i;
});
// remapColumns: The indexes of the permutation array are the current order, the values are the new order.
// new_order 0=>a 1=>c 2=>d 3=>b 4=>e
// new_order_index a=>0 c=>1 d=>2 b=>3 e=>4
// cur 0=>a 1=>b 2=>c 3=>d 4=>e
// cur_index a=>0 b=>1 c=>2 d=>3 e=>4
// permutati 0 2 3 1 4
// a c d b e
var perm = [];
$.each(cur, function(i, name){ // 2=>b
new_item = new_order[i]; // c goes here
new_item_index = cur_index[new_item];
perm[i] = new_item_index;
});
if (colModel[0].name == 'subgrid' || colModel[0].name == '')
{
perm.splice(0, 0, 0);
$.each(perm, function(i,n){
++perm[i]
});
perm[0] = 0;
}
$grid.jqGrid("remapColumns", perm, true, false);
},
});
})(jQuery);
您需要的部分工作可以使用 jqGridExport
和 jqGridImport
实现(请参见 http://www.trirand.com/jqgridwiki/doku.php?id=wiki:import_methods),但我认为您想要更多的功能,这些功能在 jqGrid 中可能没有预置。一些额外的功能需要您自己实现。
jqGridExport
和jqGridImport
提供的功能太少了,但是我不知道在jqGrid中还有什么内置的支持你的需求。你必须自己实现它。 - Oleg你可以用纯JS而不是jQuery插件来使这更简单(无需其他依赖)
var prefs = {
data: {},
load: function () {
var the_cookie = document.cookie.split(';');
if (the_cookie[0]) {
this.data = JSON.parse(unescape(the_cookie[0]));
}
return this.data;
},
save: function (expires, path) {
var d = expires || new Date(2020, 02, 02);
var p = path || '/';
document.cookie = escape( JSON.stringify(this.data) )
+ ';path=' + p
+ ';expires=' + d.toUTCString();
}
}
如何使用?
to_save = { "size": 40, "color": "green", "products":"jeans"};//and any other data/filters you wanna store here
prefs.data = to_save;
prefs.save();//now our json object is saved on the client document cookie
// delete
var date_in_the_past = new Date(2000,02,02);
prefs.save(date_in_the_past);
// read
var what = prefs.load();
// load populates prefs.data and also returns
alert(what.color);
// or ...
alert(prefs.data.color);
提示:所有现代浏览器都支持本地JSON编码/解码(Internet Explorer 8+,Firefox 3.1+,Safari 4+和Chrome 3+)。基本上,JSON.parse(str)阅读更多。 附注:我在那里使用的对象只是优化并删除了对.toJSONstring的依赖... 源代码
看看这些jQuery插件
使用这个,不要使用上面的自定义函数 https://github.com/carhartl/jquery-cookie