JqPivot 和数据加载 ajax
JqPivot and data load by ajax
Can someone post a demo or a piece of code, to exemplify how to use jqpivot and loading data using ajax.
Thank you.
我建议您检查免费的 jqGrid 的源代码。看代码的the part。看起来像
jqPivot: function (data, pivotOpt, gridOpt, ajaxOpt) {
return this.each(function () {
var $t = this, $self = $($t), $j = $.fn.jqGrid;
function pivot(data) {
...
}
if (typeof data === "string") {
$.ajax($.extend({
url: data,
dataType: "json",
success: function (data) {
pivot(jgrid.getAccessor(data, ajaxOpt && ajaxOpt.reader ? ajaxOpt.reader : "rows"));
}
}, ajaxOpt || {}));
} else {
pivot(data);
}
});
}
您几乎可以直接得到问题的答案。您需要向服务器指定 URL 以 JSON 形式提供输入数据。不直接支持其他数据格式("xml"
、"jsonp"
等),但您可以使用 ajaxOpt
参数覆盖 Ajax 调用的参数。另外需要了解的是,jqGrid 使用 $.jgrid.getAccessor
方法从服务器响应中读取数据。默认数据格式应如下所示:
{
"rows": ...
}
其中 "rows" 的值应与 jqPivot
的 data
参数具有相同的格式,如果您使用 if without Ajax。例如,如果您有
{
{
"myRoot": {
"myData": ...
}
}
}
然后你可以使用 jqPivot (ajaxOpt
) 的第 4 个参数作为
{ reader: "myRoot.myData" }
如果服务器的响应是数据数组:
[
...
]
或者它有一些非标准的形式,而不是你可以使用 reader
的函数形式。例如
$("#grid").jqGrid("jqPivot", "/myUrl", {
xDimension: [{...}],
yDimension: [{...}, ...],
aggregates: [{...}],
},
{
iconSet: "fontAwesome",
cmTemplate: { autoResizable: true, width: 80 },
shrinkToFit: false,
autoResizing: { compact: true },
pager: true,
rowNum: 20,
rowList: [5, 10, 20, 100, "10000:All"]
},
{
reader: function (obj) { return obj; },
contentType: "application/json; charset=utf-8",
type: "POST",
error: function (jqXHR, textStatus, errorThrown) {
alert('HTTP status code: ' + jqXHR.status + '\n' +
'textStatus: ' + textStatus + '\n' +
'errorThrown: ' + errorThrown);
alert('HTTP message body (jqXHR.responseText): ' + '\n' + jqXHR.responseText);
}
});
上面的代码在函数中指定了reader直接使用所有的响应数据(不带对象rows
属性)。它指定 jQuery.ajax 的 contentType
和 type
参数以及回调函数 error
.
如果您觉得所有选项都太难,您可以直接在代码中加载数据,例如直接调用 jQuery.ajax
并调用 jqPivot
after 数据已加载(在 success
回调或 done
内)。
Can someone post a demo or a piece of code, to exemplify how to use jqpivot and loading data using ajax. Thank you.
我建议您检查免费的 jqGrid 的源代码。看代码的the part。看起来像
jqPivot: function (data, pivotOpt, gridOpt, ajaxOpt) {
return this.each(function () {
var $t = this, $self = $($t), $j = $.fn.jqGrid;
function pivot(data) {
...
}
if (typeof data === "string") {
$.ajax($.extend({
url: data,
dataType: "json",
success: function (data) {
pivot(jgrid.getAccessor(data, ajaxOpt && ajaxOpt.reader ? ajaxOpt.reader : "rows"));
}
}, ajaxOpt || {}));
} else {
pivot(data);
}
});
}
您几乎可以直接得到问题的答案。您需要向服务器指定 URL 以 JSON 形式提供输入数据。不直接支持其他数据格式("xml"
、"jsonp"
等),但您可以使用 ajaxOpt
参数覆盖 Ajax 调用的参数。另外需要了解的是,jqGrid 使用 $.jgrid.getAccessor
方法从服务器响应中读取数据。默认数据格式应如下所示:
{
"rows": ...
}
其中 "rows" 的值应与 jqPivot
的 data
参数具有相同的格式,如果您使用 if without Ajax。例如,如果您有
{
{
"myRoot": {
"myData": ...
}
}
}
然后你可以使用 jqPivot (ajaxOpt
) 的第 4 个参数作为
{ reader: "myRoot.myData" }
如果服务器的响应是数据数组:
[
...
]
或者它有一些非标准的形式,而不是你可以使用 reader
的函数形式。例如
$("#grid").jqGrid("jqPivot", "/myUrl", {
xDimension: [{...}],
yDimension: [{...}, ...],
aggregates: [{...}],
},
{
iconSet: "fontAwesome",
cmTemplate: { autoResizable: true, width: 80 },
shrinkToFit: false,
autoResizing: { compact: true },
pager: true,
rowNum: 20,
rowList: [5, 10, 20, 100, "10000:All"]
},
{
reader: function (obj) { return obj; },
contentType: "application/json; charset=utf-8",
type: "POST",
error: function (jqXHR, textStatus, errorThrown) {
alert('HTTP status code: ' + jqXHR.status + '\n' +
'textStatus: ' + textStatus + '\n' +
'errorThrown: ' + errorThrown);
alert('HTTP message body (jqXHR.responseText): ' + '\n' + jqXHR.responseText);
}
});
上面的代码在函数中指定了reader直接使用所有的响应数据(不带对象rows
属性)。它指定 jQuery.ajax 的 contentType
和 type
参数以及回调函数 error
.
如果您觉得所有选项都太难,您可以直接在代码中加载数据,例如直接调用 jQuery.ajax
并调用 jqPivot
after 数据已加载(在 success
回调或 done
内)。