首页 文章

MVC绑定到模型的复选框列表

提问于
浏览
1

我在将集合绑定到模型时遇到了一些问题 . 我按照this link创建了一个复选框列表 . 我不确定要提供多少代码,但我的观点有以下模型

Public class Model1{
     public string param1{get; set;}
     public string param2{get; set;}
}

Public class Model2{
     public string param1{get; set;}
     public string param2{get; set;}
}

Public class Model3: Model2{
     public bool chk {get; set;}
     public list<string> param{get; set;}
     public Model3()
     {
        param = new List<string>(){"one", "two", "three"};
     }
}



public class superModel{
        public Model1 first{get; set;}
        public IEnumerable<Model2> second{get; set;}
        public List<Model3> third{get; set;}
   }

在我的控制器中,我已将参数第三个定义为

third = AnEnumerableList.Select( e=> new Model3{chk=false, param1 = e.Param, param2 = e.Param1}).ToList();

在我看来,我传递了超模拿着我所有的 class 模特 . 我创建一个这样的复选框:

for(int i=0; i<Model.third.Count; i++){
    @Html.CheckBoxFor(m => m.third[i].chk, new {onchange="test()"})
    @Html.HiddenFor(m => m.third[i].param)
    @Html.HiddenFor(m => m.third[i].param1)
    @Html.HiddenFor(m => m.third[i].param2)

}

javascript看起来像

function test(){
   alert('@Model.third[0].chk')
}

当我查看生成的源代码时,一切看起来都很好,但无论是否选中该复选框,javascript代码始终返回false . 提交视图表单时,整个视图不会显示 . 相反,我得到一个局部视图,其中包含第一个选中复选框的名称 . 如果在此集合中未选择任何内容,则返回的视图将正常提交 . 我试图调试代码,但在此过程中没有任何中断 .

我知道,我可能没有足够的这个问题,但这是我能尽可能多的...

1 回答

  • 1

    那个's because you'正在查看 Model 值和 not 复选框的当前值 . 您需要更改它,首先,更改您的复选框声明以传递 this ,如下所示:

    @Html.CheckBoxFor(m => m.third[i].chk, new {onchange="test(this)"})
    

    然后稍微更改您的测试功能,为:

    function test(item){
        alert(item.checked)
    }
    

相关问题