首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JqPivot与ajax数据加载

JqPivot与ajax数据加载
EN

Stack Overflow用户
提问于 2015-06-12 04:38:05
回答 1查看 1.2K关注 0票数 0

可以有人发布一个演示或一段代码,以举例说明如何使用jq透视和使用ajax加载数据。谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-06-12 05:41:00

我建议您检查一下免费jqGrid的源代码。看看代码的部分。看起来像是

代码语言:javascript
复制
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方法从服务器响应中读取数据。默认数据格式应如下:

代码语言:javascript
复制
{
    "rows": ...
}

其中“行”的值应该具有与data参数相同的格式,如果您使用if没有Ajax的话。例如,如果你有

代码语言:javascript
复制
{
    {
        "myRoot": {
            "myData": ...
        }
    }
}

然后,您可以使用jqPivot (ajaxOpt)的第4个参数作为

代码语言:javascript
复制
{ reader: "myRoot.myData" }

如果来自服务器的响应是数据数组:

代码语言:javascript
复制
[
    ...
]

或者它有一些非标准的形式,无法使用函数形式的reader。例如

代码语言:javascript
复制
$("#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);
    }
});

上面的代码指定函数处的读取器,它直接使用所有响应数据(没有带有rows属性的对象)。它指定contentTypetype参数的jQuery.ajax和回调函数error

如果所有选项看起来都太难了,您可以使用直接调用jQuery.ajax和数据加载后调用jqPivot (在success回调或done中)来加载代码中的数据指向。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30795387

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档