asp.net mvc剃须刀veiwbag不适用于实体框架tolist()

时间:2019-03-07 11:08:56

标签: asp.net-mvc entity-framework razor

我正在尝试使用 viewbag chtml 页面中的数据绑定,但无法正常工作。

我的控制器

public ActionResult ViewInvoice(decimal id)
        {
            var invoice_data = db.Invoices    // your starting point - table in the "from" statement
                            .Join(db.Users, a => a.CreatedBy, b => b.UserID, (a, b) => new { a.VehicleID, a.VehicleCheckOut, a.InvoiceID, a.InvoiceStatus, a.ChargeAmount, a.VehicleNo, a.VehicleRiderName, a.VehicleRiderPhone, a.IsVehicleExtra, a.VehicleCheckIn, a.VehicleLimitOut, b.UserFirstName, b.UserLastName, b.CreatedOn })
                            .Join(db.ParkingStatus, a => a.InvoiceStatus, b => b.PStatusID, (a, b) => new { b.PStatusName, b.PStatusKey, a.VehicleID, a.VehicleCheckOut, a.InvoiceID, a.InvoiceStatus, a.ChargeAmount, a.VehicleNo, a.VehicleRiderName, a.VehicleRiderPhone, a.IsVehicleExtra, a.VehicleCheckIn, a.VehicleLimitOut, a.UserFirstName, a.UserLastName, a.CreatedOn })
                            .Join(db.Vehicles, a => a.VehicleID, b => b.VehicleID, (a, b) => new { a.PStatusName, a.PStatusKey, a.VehicleCheckOut, a.InvoiceID, a.InvoiceStatus, a.ChargeAmount, a.VehicleNo, a.VehicleRiderName, a.VehicleRiderPhone, a.IsVehicleExtra, a.VehicleCheckIn, a.VehicleLimitOut, b.VehicleName, a.UserFirstName, a.UserLastName, a.CreatedOn })
                           .Join(db.ParkingStatus, // the source table of the inner join
                               sp => sp.InvoiceStatus,        // Select the primary key (the first part of the "on" clause in an sql "join" statement)
                               st => st.PStatusID,   // Select the foreign key (the second part of the "on" clause)
                               (sp, st) => new { sp.PStatusName, sp.PStatusKey, sp.UserFirstName, sp.UserLastName, sp.CreatedOn, sp.VehicleCheckOut, sp.InvoiceID, sp.VehicleCheckIn, sp.VehicleLimitOut, sp.IsVehicleExtra, sp.VehicleRiderName, sp.VehicleRiderPhone, sp.ChargeAmount, sp.VehicleName }).Where(x => x.InvoiceID == id).ToList();


            ViewBag.invoice_data = invoice_data;
            return View();
        }

我正在尝试访问以下内容,但不起作用

@((ViewBag.invoice_data as List<PMS.Models.Invoice>).First().InvoiceID)

以下是错误

我的Chtml页面

@{
    ViewBag.Title = "View Invoice";
    ViewBag.MainTitle = "View Invoice";
}
<section class="invoice">
                                @((ViewBag.invoice_data as List<PMS.Models.Invoice>).First().InvoiceID)
                            </section>

Error

1 个答案:

答案 0 :(得分:1)

在您的控制器代码中

(sp, st) => new { sp.PStatusName,

这是匿名类型,因此as(在视图中)失败并返回null

尝试

(sp, st) => new PMS.Models.Invoice { sp.PStatusName,

顺便说一句:使用强类型视图会更加安全。