模型(复杂类型)不会提交行动

时间:2012-11-25 19:07:15

标签: c# razor asp.net-mvc-4 complextype

我在使用“复杂类型”发布表单时遇到了一些问题。模型:

我有一个模特:

public class CircleEditViewModel
    {
        [Key]
        public int CircleId { get; set; }

        [Required]
        [MaxLength(100)]
        public string Name { get; set; }

        public bool IsSystem { get; set; }
        public class UserInCircle
        {
            public UserInCircle(User user)
            {
                this.UserId = user.UserId;
                FullName = user.FullName;

            }
            public int UserId { get; set; }
            public byte[] Picture { get; set; }
            public string FullName { get; set; }
            public bool isInCircle { get; set; }
        }
          public List<UserInCircle> Users { get; set; }
    }

我的第一个问题是,在发布会后,我的用户为空...所以我在这里点了几篇帖子(比如MVC- Model Binding on a Complex Type),使用代替代替 foreach ,但自从我这样做以来,我的表格不再发布了:

查看:

      @model Wims.Website.ViewModels.CircleEditViewModel
        <script type="text/javascript">
            $(document).ready(function () {

                $.validator.unobtrusive.parse('form');
            });


        </script>
@using (Ajax.BeginForm(Html.ViewContext.RouteData.Values["Action"].ToString(), null, new AjaxOptions { HttpMethod = "POST", OnSuccess = "SaveDone(data)" }, new { id = "editform" }))
{
    @Html.ValidationSummary(true)

            <fieldset>
                <legend>Circle</legend>
                @Html.Label(DateTime.Now.ToString());
            <div class="editor-label">
                @Html.LabelFor(model => model.Name)
            </div>
                <div class="editor-field">
                    @Html.EditorFor(model => model.Name)
                    @Html.ValidationMessageFor(model => model.Name)
                </div>
            </fieldset>

            if (Model.Users != null)
            {
                for (int i = 0; i < Model.Users.Count; i++)
                {            
                    <div class="userDetail">
                        <div>
                            <div>
                                @Html.DisplayFor(model => Model.Users[i].isInCircle);
                            </div>
                            <div class="iconDiv">
                                @Html.Image("~/Content/Images/defaultUser.jpg", Model.Users[i].FullName, null);
                            </div>
                            <div>     
                                 @Html.TextBoxFor(model => Model.Users[i].FullName)
                                 @Html.HiddenFor(model => Model.Users[i].UserId)

                            </div>
                        </div>

                    </div>
                    <div style="clear: both"></div>
                }
            }
         @Html.GenerateSecureDataControls(model => model.CircleId)
            <input type="submit" value="Save" />
        }

我的视图呈现为部分加载通过ajax(不确定它在这里有什么不同)。 知道为什么它不会发布?如果我删除所有&#39; []&#39;喜欢&#39;用户[0] .FullName&#39;我将发布给Users0.FullName,但当然不会受到约束。

感谢您的帮助

根据需要进行编辑:操作:

[HttpPost]
    public ActionResult Edit(CircleEditViewModel circleData, FormCollection collection)
    {
        if (ModelState.IsValid)
        {
            using (var logic = new CircleLogic())
            {
                Circle circle = logic.GetCircleById(circleData.CircleId, WebMatrix.WebData.WebSecurity.CurrentUserId);
                if (circle == null)
                {
                    return HttpNotFound();
                }
                else
                {

                    circle.Name = circleData.Name;
                    logic.UpdateCircle(circle, GetSelectedUser(collection));

                }
                return PartialView("_CircleAndUsers", GetData(logic, circle.CircleId));
            }
        }

        return this.Json(new { success = false, viewdata = RenderRazorViewToString("_CircleAndUsers", circleData) });

    }

1 个答案:

答案 0 :(得分:0)

Pablo Romeo是对的,我添加了一个默认的ctor,它起作用了。