Экспорт в Excel отфильтрованных данных с помощью Free jqgrid 4.15.4 в MVC - PullRequest
0 голосов
/ 24 сентября 2018

У меня есть вопрос относительно экспорта в Excel в free-jqgrid 4.15.4.Я хочу знать, как использовать этот набор результатов {"groupOp":"AND","rules":[{"field":"FirstName","op":"eq","data":"Amit"}]} в моем методе бизнес-логики.

Просто для пояснения, я использую OfficeOpenXml , и если я не использую отфильтрованный набор результатов (выше), он работает нормально, и я могу загрузить файл с полными записями влист Excel.Но я не уверен, что делать или как использовать набор результатов {"groupOp":"AND","rules":[{"field":"FirstName","op":"eq","data":"Amit"}]}

При необходимости я могу поделиться своим контроллером и кодом BL.

Я добавил скрипку, которая показывает реализациюКнопка экспорта в Excel в пейджере jqGrid.

Прежде чем перейти сюда, я прочитал и попытался понять следующие вопросы:

1] jqgrid, экспорт в Excel (с текущимфильтровать данные) на сайте asp.net-mvc

2] Экспорт отфильтрованных данных jqgrid в формате Excel или CSV

Вот код:

$(function () {
"use strict";
var mydata = [
    { id: "10",  FirstName: "test", LastName: "TNT", Gender: "Male" },
     { id: "11",     FirstName: "test2",    LastName: "ADXC", Gender: "Male" },
     { id: "12",     FirstName: "test3",    LastName: "SDR", Gender: "Female" },
     { id: "13",     FirstName: "test4",    LastName: "234", Gender: "Male" },
     { id: "14",     FirstName: "test5",    LastName: "DAS", Gender: "Male" },
];
$("#list").jqGrid({
data: mydata,

    colNames: ['Id', 'First Name', 'Last Name', 'Gender'],
     colModel: [
        {
            label: "Id",
            name: 'Id',
            hidden: true,
            search: false,
        },
        {
            label: "FirstName",
            name: 'FirstName',
            searchoptions: {
                searchOperators: true,
                sopt: ['eq', 'ne', 'lt', 'le','ni', 'ew', 'en', 'cn', 'nc'],
            }, search: true,
        },
        {
            label: "LastName",
            name: 'LastName',
            searchoptions: {
                searchOperators: true,
                sopt: ['eq', 'ne', 'lt', 'ni', 'ew', 'en', 'cn', 'nc'],
            }, search: true,
        },

        {
            label: "Gender",
            name: 'Gender',
            search: true, edittype: 'select', editoptions: { value: 'Male:Male;Female:Female' }, stype: 'select',

        },
        ],
        onSelectRow: function (id) {
        if (id && id !== lastsel) {
            jQuery('#list').restoreRow(lastsel);
            jQuery('#list').editRow(id, true);
            lastsel = id;
        }
    },
    loadComplete: function (id) {
        if ($('#list').getGridParam('records') === 0) {

            //$('#grid tbody').html("<div style='padding:6px;background:#D8D8D8;'>No records found</div>");
        }
        else {
            var lastsel = 0;
            if (id && id !== lastsel) {
                jQuery('#list').restoreRow(lastsel);
                jQuery('#list').editRow(id, true);
                lastsel = id;
              }
            }
        },      
    loadonce: true,
    viewrecords: true,
    gridview: true,
    width: 'auto',
    height: '150px',    
    emptyrecords: "No records to display",
    iconSet:'fontAwesome',
    pager: true,
    jsonReader:
    {
        root: "rows",
        page: "page",
        total: "total",
        records: "records",
        repeatitems: false,
        Id: "Id"
    },

});
jQuery("#list").jqGrid("navButtonAdd", {
    caption: "",
    buttonicon: "fa-table",
    title: "Export To Excel",
    onClickButton: function (e) {
        var projectId = null;
        var isFilterAreUsed = $('#grid').jqGrid('getGridParam', 'search'),
           filters = $('#grid').jqGrid('getGridParam', 'postData').filters;   
        var Urls = "/UsersView/ExportToExcel_xlsxFormat?filters="+ encodeURIComponent(filters); //' + encodeURIComponent(filters);/
        if (totalRecordsCount > 0) {
            $.ajax({
                url: Urls,
                type: "POST",
                //contentType: "application/json; charset=utf-8",
                data: { "searchcriteria": filters, "projectId": projectId, "PageName": "MajorsView" },
                //datatype: "json",
                success: function (data) {
                    if (true) {
                        window.location = '/UsersView/SentFiletoClientMachine?file=' + data.filename;
                    }
                    else {
                        $("#resultDiv").html(data.errorMessage);
                        $("#resultDiv").addClass("text-danger");
                    }                       
                },
                error: function (ex) {
                    common.handleAjaxError(ex.status);                        
                }
            });
        }
        else {
            bootbox.alert("There are no rows to export in the Participant List")
            if (dialog) {
                dialog.modal('hide');
            }
        }
    }
});
});

https://jsfiddle.net/ap43xecs/10/

1 Ответ

0 голосов
/ 24 сентября 2018

Существует множество вариантов решения проблемы.Самый простой способ состоит в отправке идентификаторов отфильтрованных строк на сервер вместо отправки параметра filters.Free jqGrid поддерживает параметр lastSelectedData, поэтому вы можете использовать $('#grid').jqGrid('getGridParam', 'lastSelectedData'), чтобы получить массив с отсортированными и отфильтрованными элементами, соответствующими текущему фильтру и критериям сортировки.Каждый элемент возвращаемого массива должен содержать свойство Id (или свойство id), которое можно использовать на стороне сервера для фильтрации данных перед экспортом.

Второй вариант заключается в реализации фильтрации на стороне сервера.на основе параметра filters, который вы в данный момент отправляете на сервер. Старый ответ (см. FilterObjectSet) предоставляет пример фильтрации в случае использования Entity Framework.Кстати, ответ и еще один содержат код, который я использовал для экспорта данных сетки в Excel с использованием Open XML SDK.Вы можете сравнить его с существующим кодом.

В некоторых ситуациях может быть интересно экспортировать данные сетки в Excel без написания какого-либо серверного кода.Соответствующее демо можно найти в выпуске и ОБНОВЛЕНО часть ответ .

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...