无法通过 Id Asp.Net Mvc 从 DropdownList 获取名称
Can't get Name from DropdownList by Id Asp.Net Mvc
在我的创建 (Purchase/Purchasing) 页面中,我显示了一些下拉列表,例如奥特莱斯、供应商。但是在创建之后,我没有得到奥特莱斯的名称。它通过模型传递 OutletId,我也可以在数据库中看到它。但是不知道如何根据这些 OutletId 获取名称。
Here's is the page image link in which Outlet & Supplier Names are not loading
这是我的代码--->
模型和视图模型
Purchase.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace OnlineShopping.Models.EntityModels
{
public class Purchase
{
public int Id { get; set; }
public int EmployeeId { get; set; }
public Employee Employee { get; set; }
public DateTime PurchaseDate{get;set;}
public int SupplierId { get; set; }
public Supplier Supplier { get; set; }
public string Remarks { get; set; }
public double GrandTotal { get; set; }
public List<PurchaseDetails> PurchaseDetailses { get; set; }
public int OutletId { get; set; }
public Outlet Outlet { get; set; }
public List<Outlet> Outlets { get; set; }
}
}
PurchaseVM.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using System.ComponentModel.DataAnnotations;
using OnlineShopping.Models.EntityModels;
namespace OnlineShopping.Models.VM
{
public class PurchaseVM
{
[Display(Name = "Outlet")]
public int OutletId { get; set; }
[Display(Name = "Employee")]
public int EmployeeId { get; set; }
public DateTime PurchaseDate { get; set; }
[Display(Name ="Supplier")]
public int SupplierId { get; set; }
public string Remarks { get; set; }
public double GrandTotal { get; set; }
public List<PurchaseDetails> PurchaseDetailses { get; set; }
public Outlet Outlet { get; set; }
public List<Outlet> Outlets { get; set; }
public List<Supplier> Suppliers { get; set; }
public List<Item> Items { get; set; }
public List<Employee> Employees { get; set; }
}
}
查看
Purchasing.cshtml
@model OnlineShopping.Models.VM.PurchaseVM
@{
ViewBag.Title = "Purchasing";
Layout = "~/Views/Shared/_Layout.cshtml";
}
<h2>Purchasing</h2>
@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
<div class="form-horizontal">
<div class="col-md-6">
<div class="row">
<div class="col-md-6 col-md-offset-3">
<div class="form-group">
@Html.LabelFor(c => c.OutletId, htmlAttributes: new { @class = "control-label col-md-4" })
<div class="col-md-8">
@Html.DropDownListFor(c => c.OutletId, new SelectList(Model.Outlets, "Id", "Name"), "Select...", htmlAttributes: new { @class = "form-control" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(c => c.EmployeeId, htmlAttributes: new { @class = "control-label col-md-4" })
<div class="col-md-8">
@Html.DropDownListFor(c => c.EmployeeId, null, htmlAttributes: new { @class = "form-control" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.PurchaseDate, htmlAttributes: new { @class = "control-label col-md-4" })
<div class="col-md-8">
@Html.EditorFor(model => model.PurchaseDate, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.PurchaseDate, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(c => c.SupplierId, htmlAttributes: new { @class = "control-label col-md-4" })
<div class="col-md-8">
@Html.DropDownListFor(c => c.SupplierId, new SelectList(Model.Suppliers, "Id", "Name"), "Select...", htmlAttributes: new { @class = "form-control" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.Remarks, htmlAttributes: new { @class = "control-label col-md-4" })
<div class="col-md-8">
@Html.EditorFor(model => model.Remarks, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.Remarks, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group" id="GrandTotal">
@Html.LabelFor(model => model.GrandTotal, htmlAttributes: new { @class = "control-label col-md-4" })
<div class="col-md-8">
@Html.EditorFor(model => model.GrandTotal, new { htmlAttributes = new { @class = "form-control" } })
@*@Html.ValidationMessageFor(model => model.Remarks, "", new { @class = "text-danger" })*@
</div>
</div>
</div>
</div>
</div>
<div class="col-md-6">
<div class="row">
<div class="row">
<div class="col-md-6">
<div class="form-group">
@Html.Label("Item", htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.DropDownList("Item", new SelectList(Model.Items, "Id", "Name"), htmlAttributes: new { @class = "form-control" })
</div>
</div>
<div class="form-group">
@Html.Label("Qty", htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.TextBox("Qty", null, htmlAttributes: new { @class = "form-control" })
</div>
</div>
<div class="form-group">
@Html.Label("Price", htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.TextBox("Price", null, htmlAttributes: new { @class = "form-control" })
</div>
</div>
</div>
<div class="col-md-offset-3">
<input id="addButton" class="btn btn-success" type="button" value="Add" />
</div>
</div>
<div class="row">
<table>
<thead>
<tr>
<th>Item</th>
<th>Quantity</th>
<th>Price</th>
<th>Total</th>
</tr>
</thead>
<tbody id="tbenroll"></tbody>
</table>
</div>
</div>
</div>
<div class="col-md-offset-8">
<input class="btn btn-primary" type="submit" value="Save" />
@ViewBag.Message
</div>
<p>
@Html.ActionLink("Cancel", "Index")
</p>
</div>
}
@section scripts
{
<script src="~/Scripts/Purchasing/Purchase.js"></script>
}
Index.cshtml
@model IEnumerable<OnlineShopping.Models.EntityModels.Purchase>
@{
ViewBag.Title = "Index";
}
<h2>Index</h2>
<p>
@Html.ActionLink("Create New", "Purchasing")
</p>
<table class="table">
<tr>
<th>
@Html.DisplayNameFor(model => model.Outlet)
</th>
<th>
@Html.DisplayNameFor(model => model.Supplier)
</th>
<th>
@Html.DisplayNameFor(model => model.Employee)
</th>
<th>
@Html.DisplayNameFor(model => model.PurchaseDate)
</th>
<th>
@Html.DisplayNameFor(model => model.Remarks)
</th>
<th>
@Html.DisplayNameFor(model => model.GrandTotal)
</th>
<th></th>
</tr>
@foreach (var item in Model)
{
<tr>
<td>
@Html.DisplayFor(modelItem => item.Outlet.Name)
</td>
<td>
@Html.DisplayFor(modelItem => item.Supplier.Name)
</td>
<td>@Html.DisplayFor(modelItem => item.Employee.Name)</td>
<td>
@Html.DisplayFor(modelItem => item.PurchaseDate)
</td>
<td>
@Html.DisplayFor(modelItem => item.Remarks)
</td>
<td>
@Html.DisplayFor(modelItem => item.GrandTotal)
</td>
<td>
@*@Html.ActionLink("Edit", "Edit", new { id = item.Id }) |*@
@Html.ActionLink("Details", "Details", new { id = item.Id })
@*@Html.ActionLink("Delete", "Delete", new { id = item.Id })*@
</td>
</tr>
}
</table>
控制器
采购管理员
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using AutoMapper;
using OnlineShopping.BLL;
using OnlineShopping.Models.EntityModels;
using OnlineShopping.Models.VM;
using OnlineShopping.BLL.Managers;
namespace OnlineShopping.Controllers
{
public class PurchaseController : Controller
{
OrganizationManager organizationManager = new OrganizationManager();
OutletManager outletManager = new OutletManager();
ItemManager itemManager = new ItemManager();
PurchaseOpManager purchaseOpManager = new PurchaseOpManager();
EmployeeManager employeeManager = new EmployeeManager();
SupplierManager supplierManager = new SupplierManager();
public ActionResult Index()
{
var purchaseList = purchaseOpManager.GetAll();
return View(purchaseList);
}
// GET: Purchase
public ActionResult Purchasing()
{
var model = new PurchaseVM();
model.Outlets = outletManager.GetAll();
model.Items = itemManager.GetAll();
model.Suppliers = supplierManager.GetAll();
ViewBag.EmployeeId = new List<SelectListItem>()
{
new SelectListItem() {Value = "", Text = "Select..."}
};
//ViewBag.SupplierId = new List<SelectListItem>()
//{
// new SelectListItem() {Value = "", Text = "Select.." }
//};
return View(model);
}
[HttpPost]
public ActionResult Purchasing(PurchaseVM model)
{
try
{
if (ModelState.IsValid)
{
var purchase = Mapper.Map<Purchase>(model);
bool isSaved = purchaseOpManager.Save(purchase);
if (isSaved)
return RedirectToAction("Index");
}
}
catch (Exception exception)
{
ModelState.AddModelError("", exception.Message);
var employeeList = ViewBag.EmployeeId;
model.EmployeeId = employeeList;
return View(model);
}
var outlets = outletManager.GetAll();
model.Outlets = outlets;
return View(model);
//model.Outlets = outletManager.GetAll();
//model.Items = itemManager.GetAll();
//return View(model);
}
}
}
声明 POCO class 的 属性 时使用 Virtual 关键字。
下面的示例
public class Purchase
{
public int Id { get; set; }
public int EmployeeId { get; set; }
public Virtual Employee Employee { get; set; }
public DateTime PurchaseDate{get;set;}
public int SupplierId { get; set; }
public Virtual Supplier Supplier { get; set; }
public string Remarks { get; set; }
public double GrandTotal { get; set; }
public List<PurchaseDetails> PurchaseDetailses { get; set; }
public int OutletId { get; set; }
public Virtual Outlet Outlet { get; set; }
public List<Outlet> Outlets { get; set; }
}
在我的创建 (Purchase/Purchasing) 页面中,我显示了一些下拉列表,例如奥特莱斯、供应商。但是在创建之后,我没有得到奥特莱斯的名称。它通过模型传递 OutletId,我也可以在数据库中看到它。但是不知道如何根据这些 OutletId 获取名称。
Here's is the page image link in which Outlet & Supplier Names are not loading
这是我的代码--->
模型和视图模型
Purchase.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace OnlineShopping.Models.EntityModels
{
public class Purchase
{
public int Id { get; set; }
public int EmployeeId { get; set; }
public Employee Employee { get; set; }
public DateTime PurchaseDate{get;set;}
public int SupplierId { get; set; }
public Supplier Supplier { get; set; }
public string Remarks { get; set; }
public double GrandTotal { get; set; }
public List<PurchaseDetails> PurchaseDetailses { get; set; }
public int OutletId { get; set; }
public Outlet Outlet { get; set; }
public List<Outlet> Outlets { get; set; }
}
}
PurchaseVM.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using System.ComponentModel.DataAnnotations;
using OnlineShopping.Models.EntityModels;
namespace OnlineShopping.Models.VM
{
public class PurchaseVM
{
[Display(Name = "Outlet")]
public int OutletId { get; set; }
[Display(Name = "Employee")]
public int EmployeeId { get; set; }
public DateTime PurchaseDate { get; set; }
[Display(Name ="Supplier")]
public int SupplierId { get; set; }
public string Remarks { get; set; }
public double GrandTotal { get; set; }
public List<PurchaseDetails> PurchaseDetailses { get; set; }
public Outlet Outlet { get; set; }
public List<Outlet> Outlets { get; set; }
public List<Supplier> Suppliers { get; set; }
public List<Item> Items { get; set; }
public List<Employee> Employees { get; set; }
}
}
查看
Purchasing.cshtml
@model OnlineShopping.Models.VM.PurchaseVM
@{
ViewBag.Title = "Purchasing";
Layout = "~/Views/Shared/_Layout.cshtml";
}
<h2>Purchasing</h2>
@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
<div class="form-horizontal">
<div class="col-md-6">
<div class="row">
<div class="col-md-6 col-md-offset-3">
<div class="form-group">
@Html.LabelFor(c => c.OutletId, htmlAttributes: new { @class = "control-label col-md-4" })
<div class="col-md-8">
@Html.DropDownListFor(c => c.OutletId, new SelectList(Model.Outlets, "Id", "Name"), "Select...", htmlAttributes: new { @class = "form-control" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(c => c.EmployeeId, htmlAttributes: new { @class = "control-label col-md-4" })
<div class="col-md-8">
@Html.DropDownListFor(c => c.EmployeeId, null, htmlAttributes: new { @class = "form-control" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.PurchaseDate, htmlAttributes: new { @class = "control-label col-md-4" })
<div class="col-md-8">
@Html.EditorFor(model => model.PurchaseDate, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.PurchaseDate, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(c => c.SupplierId, htmlAttributes: new { @class = "control-label col-md-4" })
<div class="col-md-8">
@Html.DropDownListFor(c => c.SupplierId, new SelectList(Model.Suppliers, "Id", "Name"), "Select...", htmlAttributes: new { @class = "form-control" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.Remarks, htmlAttributes: new { @class = "control-label col-md-4" })
<div class="col-md-8">
@Html.EditorFor(model => model.Remarks, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.Remarks, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group" id="GrandTotal">
@Html.LabelFor(model => model.GrandTotal, htmlAttributes: new { @class = "control-label col-md-4" })
<div class="col-md-8">
@Html.EditorFor(model => model.GrandTotal, new { htmlAttributes = new { @class = "form-control" } })
@*@Html.ValidationMessageFor(model => model.Remarks, "", new { @class = "text-danger" })*@
</div>
</div>
</div>
</div>
</div>
<div class="col-md-6">
<div class="row">
<div class="row">
<div class="col-md-6">
<div class="form-group">
@Html.Label("Item", htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.DropDownList("Item", new SelectList(Model.Items, "Id", "Name"), htmlAttributes: new { @class = "form-control" })
</div>
</div>
<div class="form-group">
@Html.Label("Qty", htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.TextBox("Qty", null, htmlAttributes: new { @class = "form-control" })
</div>
</div>
<div class="form-group">
@Html.Label("Price", htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.TextBox("Price", null, htmlAttributes: new { @class = "form-control" })
</div>
</div>
</div>
<div class="col-md-offset-3">
<input id="addButton" class="btn btn-success" type="button" value="Add" />
</div>
</div>
<div class="row">
<table>
<thead>
<tr>
<th>Item</th>
<th>Quantity</th>
<th>Price</th>
<th>Total</th>
</tr>
</thead>
<tbody id="tbenroll"></tbody>
</table>
</div>
</div>
</div>
<div class="col-md-offset-8">
<input class="btn btn-primary" type="submit" value="Save" />
@ViewBag.Message
</div>
<p>
@Html.ActionLink("Cancel", "Index")
</p>
</div>
}
@section scripts
{
<script src="~/Scripts/Purchasing/Purchase.js"></script>
}
Index.cshtml
@model IEnumerable<OnlineShopping.Models.EntityModels.Purchase>
@{
ViewBag.Title = "Index";
}
<h2>Index</h2>
<p>
@Html.ActionLink("Create New", "Purchasing")
</p>
<table class="table">
<tr>
<th>
@Html.DisplayNameFor(model => model.Outlet)
</th>
<th>
@Html.DisplayNameFor(model => model.Supplier)
</th>
<th>
@Html.DisplayNameFor(model => model.Employee)
</th>
<th>
@Html.DisplayNameFor(model => model.PurchaseDate)
</th>
<th>
@Html.DisplayNameFor(model => model.Remarks)
</th>
<th>
@Html.DisplayNameFor(model => model.GrandTotal)
</th>
<th></th>
</tr>
@foreach (var item in Model)
{
<tr>
<td>
@Html.DisplayFor(modelItem => item.Outlet.Name)
</td>
<td>
@Html.DisplayFor(modelItem => item.Supplier.Name)
</td>
<td>@Html.DisplayFor(modelItem => item.Employee.Name)</td>
<td>
@Html.DisplayFor(modelItem => item.PurchaseDate)
</td>
<td>
@Html.DisplayFor(modelItem => item.Remarks)
</td>
<td>
@Html.DisplayFor(modelItem => item.GrandTotal)
</td>
<td>
@*@Html.ActionLink("Edit", "Edit", new { id = item.Id }) |*@
@Html.ActionLink("Details", "Details", new { id = item.Id })
@*@Html.ActionLink("Delete", "Delete", new { id = item.Id })*@
</td>
</tr>
}
</table>
控制器
采购管理员
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using AutoMapper;
using OnlineShopping.BLL;
using OnlineShopping.Models.EntityModels;
using OnlineShopping.Models.VM;
using OnlineShopping.BLL.Managers;
namespace OnlineShopping.Controllers
{
public class PurchaseController : Controller
{
OrganizationManager organizationManager = new OrganizationManager();
OutletManager outletManager = new OutletManager();
ItemManager itemManager = new ItemManager();
PurchaseOpManager purchaseOpManager = new PurchaseOpManager();
EmployeeManager employeeManager = new EmployeeManager();
SupplierManager supplierManager = new SupplierManager();
public ActionResult Index()
{
var purchaseList = purchaseOpManager.GetAll();
return View(purchaseList);
}
// GET: Purchase
public ActionResult Purchasing()
{
var model = new PurchaseVM();
model.Outlets = outletManager.GetAll();
model.Items = itemManager.GetAll();
model.Suppliers = supplierManager.GetAll();
ViewBag.EmployeeId = new List<SelectListItem>()
{
new SelectListItem() {Value = "", Text = "Select..."}
};
//ViewBag.SupplierId = new List<SelectListItem>()
//{
// new SelectListItem() {Value = "", Text = "Select.." }
//};
return View(model);
}
[HttpPost]
public ActionResult Purchasing(PurchaseVM model)
{
try
{
if (ModelState.IsValid)
{
var purchase = Mapper.Map<Purchase>(model);
bool isSaved = purchaseOpManager.Save(purchase);
if (isSaved)
return RedirectToAction("Index");
}
}
catch (Exception exception)
{
ModelState.AddModelError("", exception.Message);
var employeeList = ViewBag.EmployeeId;
model.EmployeeId = employeeList;
return View(model);
}
var outlets = outletManager.GetAll();
model.Outlets = outlets;
return View(model);
//model.Outlets = outletManager.GetAll();
//model.Items = itemManager.GetAll();
//return View(model);
}
}
}
声明 POCO class 的 属性 时使用 Virtual 关键字。 下面的示例
public class Purchase
{
public int Id { get; set; }
public int EmployeeId { get; set; }
public Virtual Employee Employee { get; set; }
public DateTime PurchaseDate{get;set;}
public int SupplierId { get; set; }
public Virtual Supplier Supplier { get; set; }
public string Remarks { get; set; }
public double GrandTotal { get; set; }
public List<PurchaseDetails> PurchaseDetailses { get; set; }
public int OutletId { get; set; }
public Virtual Outlet Outlet { get; set; }
public List<Outlet> Outlets { get; set; }
}