在这个项目中,我们有两个列表,一个是经销商,第二个是他的产品。
到目前为止,如果您检查一个经销商,我们会取回该特定经销商的所有产品,它是用 javascript (Json) 实现的。
html (5 :)
@using (Html.BeginForm()) {
@Html.ValidationSummary(true)
<fieldset>
<legend>DealerProduct</legend>
<div class="editor-label">
@Html.LabelFor(model => model.DealerID)
</div>
<div class="editor-field">
@Html.DropDownList("DealerID", String.Empty)
@Html.ValidationMessageFor(model => model.DealerID)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.ProductID)
</div>
<div class="editor-field">
@Html.DropDownList("ProductID", String.Empty)
@Html.ValidationMessageFor(model => model.ProductID)
</div>
<p>
<input type="submit" value="@Shared.Add" />
</p>
</fieldset>
}
JavaScript (Json :)
<script type="text/javascript">
$(document).ready(function()
{
$("#DealerID").change(function ()
{
var self = $(this);
var items="";
var url = "";
url = "@Url.Action("GetDealerProducts","DealerProduct")/"+self.val();
$.ajaxSetup({ cache: false });
$.getJSON(url,function(data)
{
$.each(data,function(index,item)
{
items+="<option value='"+item.Value+"'>"+item.Text+"</option>\n";
});
$("#ProductID").html(items);
$.ajaxSetup({ cache: true });
});
});
});
</script>
控制器 :
public ActionResult GetDealerProducts(int id)
{
Dealer currentDealer = db.Dealers.Single(p => p.UserName == User.Identity.Name);
Dealer subDealer = db.Dealers.Single(s => s.DealerID == id);
List<Product> productOpenToSale = new List<Product>();
foreach (var item in currentDealer.ProductToSale)
if (!subDealer.ProductToSale.ToList().Exists(e => e.ProductID == item.ProductID))
productOpenToSale.Add(item.Product);
List<SelectListItem> productOpenToSaleList = new List<SelectListItem>();
productOpenToSale.ForEach(item => productOpenToSaleList.Add(new SelectListItem { Value = item.ProductID.ToString(), Text = item.ProductName }));
return Json(productOpenToSaleList, JsonRequestBehavior.AllowGet);
}
我真正需要的是添加(一对)产品经销商,他可以在未来销售。
当前的选项是逐个添加产品,希望提供对所有产品进行多项选择的可能性。
可能是动态 checkBoxList 或 ViewModel 中添加输入的列表上的 foreach 之类的东西 -像这样的复选框,但我不知道在经销商在第一个列表中选择并在提交时接收所有选定的产品后如何填写它..
10X 的任何帮助!(&& 对不起,我的英语不好 :)