jqGrid с виртуальной прокруткой не возвращает записи в правильном порядке - PullRequest
0 голосов
/ 19 мая 2011

Мы используем jqGrid 3.8.2 с виртуальной прокруткой для прокрутки списка записей.Это хорошо работает, если пользователь медленно прокручивает список.Как только пользователь берет полосу прокрутки и быстро прокручивает ее до самого конца, записи, возвращаемые в сетке, полностью выходят из строя и иногда дублируются.Вызов AJAX, который мы делаем для получения записей, вызывает службу WCF, которая возвращает записи из базы данных в обратный вызов AJAX в jqGrid, в котором данные затем загружаются в сетку.База данных ожидает номер страницы, который, в свою очередь, указывает, какую страницу записей мы хотим.

Я почти уверен, что результаты возвращаются в неправильном порядке из-за синхронизации вызовов AJAX.Это означает, что звонки не всегда на первом месте.Более новые вызовы, вероятно, возвращаются обратно в jqGrid до более ранних вызовов.

Есть мысли о том, как заставить это работать правильно?Любые шаги, которые я мог бы предпринять, чтобы помочь нам двигаться в правильном направлении?

Если это поможет, вот конфигурация js:

PersonalListContactGridControl.GetGridConfig = function() {
    var jqGridConfig = {
        url: Common.AjaxService.serviceUrl + "/GetPersonalListContacts",
        datatype: "JSON",
        ajaxGridOptions: { contentType: "application/json; charset=utf-8" },
        mtype: "POST",
        autowidth: true,
        height: PersonalListContactGridControl.Constants.Height,
        altRows: true,
        sortname: "LastName",
        viewrecords: true,
        emptyrecords: "",
        loadtext: '',
        multiselect: true,
        //sortorder: "desc",

        //- virtual scrolling:: 1 ON / 0 OFF
        loadonce: false, // SUPPORT FOR REBIND
        rowNum: PersonalListContactGridControl.Constants.GridPageSize,
        scroll: 1,

        gridview: true,

        //- column header text
        colNames: ['EndPointID',
            PersonalListContactGridControl.Constants.FirstNameColumnDisplayText,
            PersonalListContactGridControl.Constants.LastNameColumnDisplayText,
            PersonalListContactGridControl.Constants.EmailFaxColumnDisplayText,
            PersonalListContactGridControl.Constants.TypeColumnDisplayText],
        //- column specific definitions
        colModel: [
            { name: 'EndPointID', index: 'EndPointID', hidden: true },
            { name: 'FirstName', index: 'FirstName', width: 155, align: 'left', editable: false, title: true,
              hidden: false, resizable: true, sortable: true, editoptions: { readonly: true },
              formatter: PersonalListContactGridControl.formatLink },
            { name: 'LastName', index: 'LastName', width: 155, align: 'left', editable: false, title: true,
              hidden: false, resizable: true, sortable: true, editoptions: { readonly: true },
              formatter: PersonalListContactGridControl.formatLink },
            { name: 'EmailAddress', index: 'EmailAddress', width: 240, align: 'left', editable: false, title: true,
              hidden: false, resizable: true, sortable: true, editoptions: { readonly: true },
              formatter: PersonalListContactGridControl.formatEmailFax },
            { name: 'EndPointType', index: 'EndPointType', width: 60, align: 'left', editable: false, title: true,
              hidden: false, resizable: true, sortable: true,  editoptions: { readonly: true },
              formatter: PersonalListContactGridControl.formatType }
        ],

        //- jqGrid's "reader" ... the structure of the JSON/XML returned (Fiddler) must match this
        jsonReader: {
            root: "d.Contacts",
            total: function(obj) {
                return Math.ceil(obj.d.TotalRecords / PersonalListContactGridControl.Constants.GridPageSize);
            },
            records: function(obj) {
                return obj.d.TotalRecords;
            },
            id: 'EndPointID',
            repeatitems: false
        },

        serializeGridData: function(jqGridParms) {
            //alert(jqGridParms.page);
            return PersonalListContactGridControl.GetRequest(jqGridParms);
        },
        loadComplete: function(data) {
            if (data.d) {
                if (data.d.ResponseProperties.Success === false) {
                    if (data.d.ResponseProperties.ErrorMessage.indexOf('The List has been deleted') > -1) {
                        ManagePersonalList.OnPersonalListErrorHandler();
                        return;
                    }
                }
                var grid = PersonalListContactGridControl.Grid();
                if (data.d.Contacts == null || data.d.Contacts.length == 0) { // are there any records?
                    // check if row exists
                    if (!grid.getInd(-1)) {
                        if (PersonalListContactGridControl.SearchString == "") {
                            grid.addRowData(-1, { "FirstName": PersonalListContactGridControl.Constants.NoContactDisplayText });
                        }
                        else {
                            grid.addRowData(-1, { "FirstName": PersonalListContactGridControl.Constants.NoContactForSearchDisplayText });
                        }
                        grid.find('#-1 input').hide(); // takeout the selection checkbox
                    }
                    PersonalListGridControl.ToggleExportButton(false);
                }
                else {
                    if (PersonalListContactGridControl.Constants.dtoToSelectID != null) {
                        if (PersonalListContactGridControl.SelectContactById(PersonalListContactGridControl.Constants.dtoToSelectID, true))
                            PersonalListContactGridControl.Constants.dtoToSelectID = null;
                    }
                    PersonalListGridControl.ToggleExportButton(true);
                }
                // cache the return objects
                PersonalListContactGridControl.DTOS = PersonalListContactGridControl.DTOS.concat(data.d.Contacts);
                PersonalListContactGridControl.InitRows();
            }
        },
        loadError: function(xhr, status, error) {
            alert("Type: " + status + "; Response: " + xhr.status + " " + xhr.statusText);
        },

        onCellSelect: function(rowid, iCol, cellcontent, e) {
            if (iCol == 0)
                PersonalListContactGridControl.CheckItem();
            else
                PersonalListContactGridControl.SelectContactById(rowid);
        },

        onSelectRow: function(id, status) {
            if (!status) return;
        },
        onSelectAll: function() {
            var grid = PersonalListContactGridControl.Grid();
            var selections = new Array();
            selections = grid.getGridParam('selarrrow');
            if (selections[0] == -1) {
                //if -1, then no rows are available
                PersonalListContactGridControl.UpdateHeaderCount(0);
            }
            else {
                PersonalListContactGridControl.UpdateHeaderCount(selections.length);
                ManagePersonalList.OnSelectAllChanged(this, { Ids: selections });
            }
        }
    };

    return jqGridConfig;
}

1 Ответ

0 голосов
/ 04 июля 2011

Попробуйте изменить JSONReader на ..

    jsonReader: {
        root: "d.Contacts",
        page: "d.currpage",
        total: "d.totalpages",
        records: "d.TotalRecords",
        id: 'EndPointId',
        repeatitems: false
    },

d.totalpages и d.currpage должны возвращаться из вызова AJAX

...