0

在这个项目中,我们有两个列表,一个是经销商,第二个是他的产品。

到目前为止,如果您检查一个经销商,我们会取回该特定经销商的所有产品,它是用 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 的任何帮助!(&& 对不起,我的英语不好 :)

4

2 回答 2

1

你可以改变这行代码

@Html.DropDownList("ProductID", String.Empty)

像这样的东西

<select id="SelectedItemIds" multiple="multiple" name="SelectedItemIds">

并在服务器上有一个像这样的viewModel

class MyViewModel
{
    public int[] SelectedItemIds { get; set; }
    public int DealerID {get;set;}
}

并拥有这样的控制器

    [HttpPost]
    public ActionResult Index(MyViewModel myViewModel)
    {
        return View();
    }
于 2012-11-06T10:26:05.830 回答
0

我有类似的情况并使它在这里工作:在此处 输入链接描述

但我不知道如何将实际文本传回。我只能将所选项目的索引传递回控制器。如果你弄清楚了,请告诉我。

确保您的选择名称与模型中的变量名称匹配。

于 2015-06-16T20:52:34.100 回答