【问题标题】:Model is null while submitting the form in partial view in MVC5在 MVC5 中以部分视图提交表单时模型为空
【发布时间】:2015-12-03 15:19:25
【问题描述】:

我只是想学习 MVC 并面临一些问题。当我提交部分视图时,我在 Create Method 内的 Model Blog 中得到空值。

我做错了什么,正确的方法是什么?

查看(Index.cshtml)

@model IEnumerable<Samples.Controllers.Blog>

@{
    ViewBag.Title = "Index";
}

<h2>Index</h2>

<p>
    @Html.ActionLink("Create New", "Create")
</p>
<table class="table">
    <tr>
        <th>Sample</th>
        <th>URL</th>
        <th>Name</th>
    </tr>

@foreach (var item in Model) {
    <tr>
        <td>
            @Html.ActionLink("Edit", "Edit", new { /* id=item.PrimaryKey */ }) |
            @Html.ActionLink("Details", "Details", new { /* id=item.PrimaryKey */ }) |
            @Html.ActionLink("Delete", "Delete", new { /* id=item.PrimaryKey */ })
        </td>
        <td>
            @item.URL
        </td>
        <td>
            @item.Name
        </td>
    </tr>
}

</table>

@Html.Partial("_CreateBlog", new Samples.Controllers.Blog())

部分视图(_CreateBlog.cshtml)

@model Samples.Controllers.Blog

@using (Html.BeginForm("Create","Sample",FormMethod.Post)) 
{
    @Html.AntiForgeryToken()

    <div class="form-horizontal">
        <h4>Blog</h4>
        <hr />
        @Html.ValidationSummary(true, "", new { @class = "text-danger" })
        <div class="row">
            @Html.LabelFor(model => model.URL)
            @Html.EditorFor(model => model.URL)
        </div>
        <div class="row">
            @Html.LabelFor(model => model.Name)
            @Html.EditorFor(model => model.Name)
        </div>
        <div class="form-group">
            <div class="col-md-offset-2 col-md-10">
                <input type="submit" value="Create" class="btn btn-default" />
            </div>
        </div>
    </div>
}

<div>
    @Html.ActionLink("Back to List", "Index")
</div>

SampleController.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;

namespace Samples.Controllers
{
    public class SampleController : Controller
    {
        List<Blog> lstBlogs;
        public SampleController() 
        {
            lstBlogs = new List<Blog> 
           {
               new  Blog{ Name="Domnic", URL=   "www.google.com"},
               new  Blog{ Name="Tom", URL=   "www.YAHOO.com"},
               new  Blog{ Name="Cat", URL=   "www.facebook.com"},
               new  Blog{ Name="Bob", URL=   "www.twitter.com"}
           };
        }
        // GET: Sample
        public ActionResult Index()
        {
            return View(lstBlogs);
        }
        public ActionResult IndexWithDynamicView()
        {
            return View(lstBlogs);
        }

        [HttpPost]
        public void Create(Blog blog)
        { 

        }
    }
    public class Blog
    {
        public string Name;
        public string URL;
    }

}

【问题讨论】:

    标签: asp.net-mvc asp.net-mvc-4 razor asp.net-mvc-5 model-binding


    【解决方案1】:

    您的类 Blog 仅包含字段,不包含属性,因此 DefaultModelBinder 无法设置它们的值。更改它添加 getter/setter

    public class Blog
    {
        public string Name { get; set; }
        public string URL { get; set; }
    }
    

    【讨论】:

      【解决方案2】:

      也许这个答案与您的问题有关:Is there a reason why the default modelbinder doesn't bind to fields?

      关注DefaultModelBinderModelBinderContextModelMetadata。这说明了一切。

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2019-11-15
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多