asp.net mvc:使用formcollection创建列表框

时间:2011-08-19 17:32:54

标签: asp.net asp.net-mvc listbox selectlist formcollection

我在视图中遇到了当前错误:

<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master"  Inherits="System.Web.Mvc.ViewPage<ProjectenII.Models.Domain.StudentModel>"%>

<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
    IndexStudents
</asp:Content>

<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
    <h2>IndexStudents</h2>

  <%using (Html.BeginForm()) { %>
    <%=Html.ListBoxFor(model => model.NormalSelected, new MultiSelectList(Model.NormalStudentsList, "StudentNummer", "Naam", Model.NormalSelected), new { size = "6" }); %>

    <input type="submit" name="add" 
                          id="add" value=">>" /><br />
    <input type="submit" name="remove" 
                          id="remove" value="<<" />
    <%=Html.ListBoxFor(model => model.NoClassSelected, new MultiSelectList(Model.StudentsNoClassList, "StudentNummer", "Naam", Model.NoClassSelected)); %>
  <% } %>

  <%=Html.HiddenFor(model => model.Save) %>
  <input type="submit" name="apply" id="apply" value="Save!" />
</asp:Content>

它在listboxfor()方法中给出了一个错误...说“)expect”。

但我关闭所有开场标签......虽然很奇怪! 我想用它来做什么:我想将项目从一个列表框移动到另一个列表框然后更新数据库。所以我想使用formCollection来做,除非有另一种方法吗?

学生有一个名为“classID”的字段,当我更新数据库时,该值需要从当前值更改为“0”。我认为最好的方法是使用formCollections?不是吗? 这是我的StudentModel

   public class StudentModel
    {
        public IEnumerable<Student> NormalStudentsList { get; set; }
        public IEnumerable<Student> StudentsNoClassList { get; set; }
        public string[] NormalSelected { get; set; }
        public string[] NoClassSelected { get; set; }
        public string Save { get; set; }
    }

控制器:

 public ActionResult IndexStudents(Docent docent, int id, int klasgroepid)
        {
            var studentModel = new StudentModel
            {
               NormalStudentsList = docent.GeefStudenten(id, klasgroepid),
               StudentsNoClassList = docent.GeefStudenten(id, klasgroepid)
            };

            return View(studentModel);
        }

我有两个问题:如何修复错误?以及如何更新数据库?

我建议使用“UpdateModel()”......?

提前致谢!!

1 个答案:

答案 0 :(得分:1)

不确定您的第二个问题是什么,因为您没有包含用于将模型持久保存到数据库的代码。

“)”预期错误是因为您在ListBoxFor方法调用结束时有一个分号。

它应该是这样的:

<%=Html.ListBoxFor(model => model.NormalSelected, new MultiSelectList(Model.NormalStudentsList, "StudentNummer", "Naam", Model.NormalSelected), new { size = "6" }) %>

使用&lt;%=时,不需要分号。