使用TempData的[ 「」]對象創建會話狀態。
您的視圖模型應該看起來有點像:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.ComponentModel;
using MvcContrib.Pagination;
using MvcContrib.UI.Grid;
using System.Web.Mvc;
namespace MyMVCProject.ViewModels
{
public class SubscriptionViewModel
{
public int SubscriptionID { get; set; }
public string SubNo { get; set; }
}
public class SubscriptionListContainerViewModel
{
public IPagination<SubscriptionViewModel> SubscriptionPagedList { get; set; }
public SubscriptionFilterViewModel Filters { get; set; }
public GridSortOptions GridSortOptions { get; set; }
public int? TotalCount { get; set; }
}
public class SubscriptionFilterViewModel
{
public int? CustomerID { get; set; }
public int? PlanID { get; set; }
}
}
控制器操作:
public ActionResult Index(SubscriptionListContainerViewModel model, GridSortOptions gridSortOptions, int? page)
{
SubscriptionFilterViewModel filter = new SubscriptionFilterViewModel();
if (model.Filters != null)
{
filter.CustomerID = model.Filters.CustomerID;
filter.PlanID = model.Filters.PlanID;
}
TempData["Filters"]=filter;
//code for IPagination<SubscriptionViewModel> population.
}
導出功能:
public void Export()
{
SubscriptionFilterViewModel filter = (SubscriptionFilterViewModel)TempData["Filters"];
TempData["Filters"]=filter;
//code for IPagination<SubscriptionViewModel> population and excel creation.
//output the excel after creation
Guid fileId = Guid.NewGuid();
string strFileName = Convert.ToString(fileId) + ".xls";
string strFilePathnName = HttpContext.Server.MapPath ("~/Content/Uploads/Excels/Export/") + strFileName;
MemoryStream file = new MemoryStream();
hssfworkbook.Write(file);
System.IO.File.WriteAllBytes(strFilePathnName, file.GetBuffer());
System.IO.FileInfo inf = new FileInfo(strFilePathnName);
HttpContext.Response.AddHeader("Content-Disposition", "attachment; filename=Blogs" + inf.Extension);
HttpContext.Response.ContentType = "application/ms-excel";
HttpContext.Response.TransmitFile(HttpContext.Server.MapPath ("~/Content/Uploads/Excels/Export/" + strFileName));
}
呼叫在您的 「導出到Excel」 導出操作按鈕點擊。
謝謝你的評論,但我看起來很不一樣。我做的和傑里米的非常相似。 public ActionResult Export(){ \t \t \t var customers = customerRepository.FindAll(); \t \t \t返回新ExcelResult(顧客) \t \t \t \t .Columns(柱=> { \t \t \t \t \t column.For(X => x.Id); \t \t \t \t \t柱。 (x => x.Name) \t \t \t \t \t column.For(x => x.DateOfBirth).Format(「{0:d}」); \t \t \t \t}); \t \t} –
2012-01-24 13:40:01