2016-11-29 83 views
-1

这是我的项目发送的产品清单中MVC

public class RequestViewModel 
{  
    public long FeederId { set; get; } 

    public int A { set; get; } 

    public int B { set; get; } 

    public int C { set; get; } 

    public int Remain { set; get; } 
} 

,这是我想从我的形式发送到我的控制器

public class RequestAddListViewModel 
{ 
    public List<SuppliantRequestFeederAddViewModel> SuppliantRequestFeederAddViewModels { set; get; } 

    public List<SelectListItem> FeederSelectListItems { set; get; } 

    public long NodeId { set; get; } 
} 

第一次我的窗体加载我我的新增模式有一个项目,我有一个button当我是我的第一行克隆和append到我的存在,例如单击现在我有我的形式8项,我可以在客户端删除的各个项目。如果我没有删除任何项目并提交表单没有问题。 我的问题是当删除一个项目,例如第二个删除时,然后提交我的表单没有我的控制器上的项目。没有发送给控制器。

查看

@for (int index = 0; index < Model.RequestAddListViewModel.Count; index++) 
{ 
    var req = Model.RequestAddListViewModel[index]; 
    <tr class="requestrow"> 
     <td> 
      @Html.DropDownListFor(p => p.req[index].FeederId,  Model.FeederSelectListItems, new { @class = "form-control" }) 
     </td> 
     <td> 
      @Html.TextBoxFor(p => p.req[index].A, new { @class = "form-control" }) 
     </td> 
     <td> 
      @Html.TextBoxFor(p => p.req[index].B, new { @class = "form-control" }) 
     </td> 
     <td> 
      @Html.TextBoxFor(p => p.req[index].C, new { @class = "form-control" }) 
     </td> 
     <td> 
      <button type="button" class="btn btn-primary btn-icon btn-rounded newfeeder"><i class="icon-plus2"></i></button> 
     </td> 
    </tr> 
} 

和我的jQuery脚本(编辑)

var inputCount=0; 
$(document).on('click', '.newfeeder', function() { 
    inputCount++; 
    var tr = $(this).closest("tr").clone(); 
    tr.find("input").val(0); 
    tr.find("button").removeClass("btn-primary").addClass("btn-danger").removeClass("newfeeder").addClass("deleterow"); 
    tr.find("button i").removeClass("icon-plus2").addClass("icon-trash"); 
    tr.find("input,select").each(function() { 
     $(this).attr({ 
      'name': function (_, name) { return name.toString().replace('0', inputCount) }, 
      'id': function (_, id) { return id.toString().replace('0', inputCount) } 
     }); 

    }); 
    $(this).closest("tr").after(tr); 
}); 

$(document).on('click', '.deleterow', function() { 
    $(this).closest("tr").remove(); 
}); 
+0

您需要添加一个隐藏的输入为集合索引。请参阅[这个答案](http://stackoverflow.com/questions/28019793/submit-same-partial-view-called-multiple-times-data-to-controller/28081308#28081308)。既然你有一个下拉列表,那么使用'BeginCollectionItem()'方法。而且你要VAR TR = $(本).closest(“TR”)的clone();'的代码行不正确地工作,以便能够绑定到你的模型,当您提交 –

+0

@StephenMuecke,请看看编辑的零件。 –

+0

你看看链接,看看如何正确地做:) –

回答

0

终于,我发现我的解决方案后,添加或删除新的项目,以我的形式 我调用这个函数ReCreateIndex()

function ReCreateIndex(container) { 
    $(container).each(function (index, obj) { 
     $("input,select", $(this)).each(function() { 
      if ($(this).attr("name")) { 
       var name = $(this).attr("name").replace($(this).attr("name").replace(/[^0-9]/gi, ''), index); 
       $(this).attr("name", name); 
      } 

      if ($(this).attr("id")) { 
       var id = $(this).attr("id").replace($(this).attr("id").replace(/[^0-9]/gi, ''), index); 
       $(this).attr("id", id); 
      } 
     }); 
    }); 
} 

这意味着在对项目进行任何更改后,重新创建项目的索引。

相关问题