10

我有两个要返回视图的列表,“已添加”和“已删除”。但是目前我只能返回“添加”或“删除”。我怎样才能在一个对象中返回两者?我对 MVC 很陌生,如果这段代码很乱,我深表歉意!

public ActionResult Index()
    {
        // Excel upload history

        var fptexcel = db.FPTStaticDataRatedFinancialAssetBase
                       .OrderBy(e => e.FORATExcelId)
                       .Select(e => e.FORATExcelId).Max();

        var fptexcelprevious = fptexcel - 1;

        var newassets = db.FPTStaticDataRatedFinancialAssetBase.OfType<FPTStaticDataRatedFinancialAssetBase>()
                        .Where(c => c.FORATExcelId == fptexcel || c.FORATExcelId == fptexcelprevious)
                        .GroupBy(x => x.Name)
                        .Where(c => c.Count() == 1)
                        .Select(y => y.FirstOrDefault()).ToList();

        var added = db.FPTStaticDataRatedFinancialAssetBase.OfType<FPTStaticDataRatedFinancialAssetBase>()
                         .Where(x => x.FORATExcelId == fptexcelprevious)
                         .Select(x => x).ToList();

        var removed = db.FPTStaticDataRatedFinancialAssetBase.OfType<FPTStaticDataRatedFinancialAssetBase>()
                         .Where(x => x.FORATExcelId == fptexcel)
                         .Select(x => x).ToList();

        return View(newassets.Except(added).ToList());

    }
4

3 回答 3

13

强烈键入您的视图,使其作为关联模型,即包含两个列表的自定义对象。请注意,这样的对象通常称为“viewModel”。

例子:

您的视图模型:

public class MyViewModel
{
    public List<X> Added { get; set; }
    public List<X> Removed { get; set; }
}

你的控制器:

public ActionResult Index()
{
    var viewModel = new MyViewModel
    {
        Added = ...,
        Removed = ...
    };
    return View(viewModel);
}

您的看法:

@model XXXXX.MyViewModel
...
于 2013-11-07T15:10:13.940 回答
7

为什么没有包含这 2 个列表的 ViewModel

return View(new MyModel{List1 = list1,List2 = list2});

或者

ViewData["List1"] = list1;
ViewData["List2"] = list2;
return View();

看看这里: http: //www.howmvcworks.net/OnViews/BuildingASstronglyTypedView

我想你想要第一个。

于 2013-11-07T15:08:45.107 回答
1

尝试使用像 ViewBag 这样的动态类型

您可以在 Razor 视图中访问 @viewbag

于 2013-11-07T15:13:09.853 回答