5

我目前有一个包含两个文本框的视图,用户可以在其中输入一些数据。一个文本框只允许 1-10 的值,另一个是字符串。我不确定我做了什么代码更改,但接受字符串的第二个文本框不再“有效”。例如,当我输入一个字符串并尝试提交表单时,我收到一条验证消息,指出“值“(字符串)”无效。下面是我的解决方案中的一些代码片段。

实体:

public class MovieReview
{
    public int Id { get; set; }

    [Range(1, 10)]
    [Required]
    public int Rating { get; set; }
    public string Review { get; set; }
    public int MovieId { get; set; }
}

控制器:

public class ReviewsController : Controller
{
    private MovieLoversDb _db = new MovieLoversDb();

    public ActionResult Index([Bind(Prefix = "id")]int movieId)
    {
        var movie = _db.Movies.Find(movieId);
        if (movie != null)
        {
            return View(movie);
        }
        return HttpNotFound();
    }

    [HttpGet]
    public ActionResult Create(int movieId)
    {
        return View();
    }

    [HttpPost]
    public ActionResult Create(MovieReview review)
    {
        if (ModelState.IsValid)
        {
            _db.MovieReviews.Add(review);
            _db.SaveChanges();
            return RedirectToAction("Index", new { id = review.MovieId });
        }
        return View(review);
    }

局部视图:

@model MovieLovers.Models.MovieReview

@{
    ViewBag.Title = "Review a Movie";
}

<h2>Review a Movie</h2>

@using (Html.BeginForm()) {
    @Html.AntiForgeryToken()
    @Html.ValidationSummary(true)

<fieldset>
    <legend>New Review</legend>

    <div class="editor-label">
        @Html.LabelFor(model => model.Rating)
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.Rating)
        @Html.ValidationMessageFor(model => model.Rating)
    </div>

    <div class="editor-label">
        @Html.LabelFor(model => model.Review)
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.Review)
        @Html.ValidationMessageFor(model => model.Review)
    </div>

    <div class="editor-label">
        @Html.LabelFor(model => model.ReviewerName)
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.ReviewerName)
        @Html.ValidationMessageFor(model => model.ReviewerName)
    </div>
    <p>
        <input type="submit" value="Create" />
    </p>
</fieldset>
}

现在的问题是,我做错了什么?为什么会产生验证错误?

4

7 回答 7

5

我在原始帖子下的评论中使用 Jasen 的建议解决了这个问题。似乎“评论”可能已经使用了两次,尽管我找不到在哪里。我将属性名称更改为“body”,现在它可以工作了。

感谢你的帮助!

于 2013-05-22T06:14:27.223 回答
3

问题是该字段的名称是 review:

@Html.EditorFor(model => model.Review)

作为控件中参数的名称:

public ActionResult Create(MovieReview 评论)

更改参数的名称也应该有效

于 2015-06-11T19:23:38.407 回答
1

请尝试使用

public class MovieReview
{
    public int Id { get; set; }

    [Range(1, 10)]
    [Required]
    public int Rating { get; set; }
    public string? Review { get; set; }
    public int MovieId { get; set; }
}
于 2013-05-22T04:35:07.360 回答
1

它不起作用,因为您的域类具有名为 Review ( public string Review { get; set; }) 的属性,并且接收更新的域类的方法也具有名为 review ( public ActionResult Create(MovieReview review)) 的参数。

更改public ActionResult Create(MovieReview review)public ActionResult Create(MovieReview movieReview)

于 2014-11-21T10:23:57.647 回答
0

我认为在下面的 model.Review 和 Model.Rating 不能直接访问,因为您的模式是 IEnumerable

     <th>
        @Html.DisplayNameFor(model => model.Rating)
    </th>
    <th>
        @Html.DisplayNameFor(model => model.Review)
    </th>
于 2013-05-20T03:41:00.807 回答
0

您的 var 名称不应与类名相同,请尝试以下操作:

public class MovieReview
{
    public int Id { get; set; }

    [Range(1, 10)]
    [Required]
    public int ratingId { get; set; }
    public string reviewText { get; set; }
    public int movieId1 { get; set; }
}
于 2016-08-22T08:24:07.333 回答
-1

去除@Html.ValidationSummary(true)

或者

全部删除ValidationMessageFor并更改为(删除真) @Html.ValidationSummary()

编辑:

您想全部删除ValidationMessageFor并将其更改ValidationSummary(true)ValidationSummary()

于 2013-05-22T04:29:19.577 回答