HTML-таблица экспорта к Excel

У меня есть HTML-таблица на странице ASP.NET MVC View. Теперь я должен экспортировать эту таблицу в Excel.

(1) Я использовал частичное представление (Inquiries.ascx) для отображения данных таблицы из базы данных (использующий LINQ для Объекта) (2), я также использовал плагин UITableFilter для фильтрации записей (Исключая: http://gregweber.info/projects/demo/flavorzoom.html)

(3) В любом моменте времени я должен отфильтровать видимые записи на Excel.

Цените свои ответы.

Спасибо

Rita

Вот мое Представление:

<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Mvc.Master" Inherits="System.Web.Mvc.ViewPage" %>




     




//Main Content

View All Inquiries

Пользовательский элемент управления представления Partial Со строгим контролем типов (Inquiries.ascx) для генерации таблицы:

Filter Expression: <%= Html.TextBox("searchName")%>
<% foreach (var item in Model) { %> <% } %>
Tx_ID TX Date Name Email Address Products Document Name
<%= item.RequestID %> <%= String.Format("{0:d}", item.RequestDate) %> <%= item.CustomerName %> <%= Html.Encode(item.Email) %> <%= item.ProductName %> <%= Html.Encode(item.DocDescription)%>

Вот мой код Контроллера для загрузки Запросов частичное представление:

[HttpGet]
        public PartialViewResult Inquiries()
        {
var model = from i in myEntity.Inquiries
  where i.User_Id == 5
                        orderby i.TX_Id descending
                        select new {
                            RequestID = i.TX_Id,
                            CustomerName = i.CustomerMaster.FirstName,
                            RequestDate = i.RequestDate,
                            Email = i.CustomerMaster.MS_Id,
                            DocDescription = i.Document.Description,
                            ProductName = i.Product.Name
                        };
            return PartialView(model);
        }

5
задан Bill Paetzke 19 February 2010 в 04:03
поделиться

1 ответ

Попробуйте плагин jQuery: table2csv . Используйте аргумент delivery: 'value', чтобы вернуть csv в виде строки.

Вот реализация:

  1. Добавьте на страницу обычную кнопку ввода html и .NET HiddenField.
  2. Добавьте к этой кнопке событие onclick под названием «Экспорт».
  3. Создайте функцию javascript Export, которая сохраняет возвращаемое значение table2CSV () в скрытое поле и отправляет обратно.
  4. Сервер получает пост-данные скрытого поля (csv в виде строки)
  5. Сервер выводит строку в браузер как файл csv

.

// javascript  
function Export()  
{    
    $('#yourHiddenFieldId').val() = $('#yourTable').table2CSV({delivery:'value'});  
    __doPostBack('#yourExportBtnId', '');  
}

// c#  
if(Page.IsPostBack)  
{
    if(!String.IsNullOrEmpty(Request.Form[yourHiddenField.UniqueId]))  
    {  
        Response.Clear();  
        Response.ContentType = "text/csv";  
        Response.AddHeader("Content-Disposition", "attachment; filename=TheReport.csv");  
        Response.Flush();  
        Response.Write(Request.Form[yourHiddenField.UniqueID]);  
        Response.End();  
    }  
}
5
ответ дан 14 December 2019 в 19:12
поделиться
Другие вопросы по тегам:

Похожие вопросы: