gpt4 book ai didi

c# - 自定义 View 引擎与自定义操作结果

转载 作者:行者123 更新时间:2023-12-02 01:21:45 26 4
gpt4 key购买 nike

我有一个场景,用户可以选择单击“下载”按钮,我应该创建一个包含历史数据的 csv 文件,然后让用户在本地保存该文件。由于我以前没有这样做过,所以我开始寻找如何执行此操作,并且基本上遇到了自定义 View 引擎和自定义操作结果。

我现在的问题是这些有什么好处/坏处?首选的方法是什么?

CSV 文件基本上只包含标题和数千行数据(最多约 15 列/字段)。所以真的没什么特别的。

最佳答案

我可能会选择自定义操作结果(我的示例中的实际序列化是通过 FileHelpers 完成的):

public class CsvResult<T> : ActionResult
{
public IEnumerable<T> Records { get; private set; }
public CsvResult(IEnumerable<T> records)
{
Records = records;
}

public override void ExecuteResult(ControllerContext context)
{
var response = context.HttpContext.Response;
response.ContentType = "text/csv";
var engine = new FileHelperEngine(typeof(T));
engine.WriteStream(response.Output, Records);
}
}

[DelimitedRecord(",")]
public class Customer
{
public int Id { get; set; }
public string Name { get; set; }
}

public class HomeController : Controller
{
public ActionResult Index()
{
var customers = new[]
{
new Customer { Id = 1, Name = "customer 1" },
new Customer { Id = 2, Name = "customer 2" },
};
return new CsvResult<Customer>(customers);
}
}

您甚至可以通过使用扩展方法来美化此返回语句(在这种情况下,泛型是丑陋且多余的):

public static class ControllerExtensions
{
public static ActionResult Csv<T>(this Controller controller, IEnumerable<T> records)
{
return new CsvResult<T>(records);
}
}

然后简单地:

public ActionResult Index()
{
var customers = new[]
{
new Customer { Id = 1, Name = "customer 1" },
new Customer { Id = 2, Name = "customer 2" },
};
return this.Csv(customers);
}

关于c# - 自定义 View 引擎与自定义操作结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3310698/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com