Attualmente ho una vista che contiene due caselle di testo in cui gli utenti possono inserire alcuni dati. Una casella di testo consente solo valori di 1-10, l'altra una stringa. Non sono sicuro del codice che ho apportato, ma la seconda casella di testo che accetta una stringa non funziona più. Ad esempio, quando inserisco una stringa e provo a inviare il modulo, viene visualizzato un messaggio di convalida che indica "Il valore" (stringa) "non è valido. Di seguito sono riportati alcuni frammenti di codice nella mia soluzione.Il valore "(stringa)" non è valido
Entità:
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; }
}
controller:
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);
}
parziale Vista:
@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>
}
La domanda n è, cosa sto sbagliando? Perché questo errore di convalida genera?
Penso che tu abbia pubblicato un'altra vista. La tua vista pubblicata mostra solo la lista. Ho ragione? –
Sì, mi scuso. Aggiornamento ora. –
Avete un altro campo sulla pagina renderizzata chiamato 'Review'? – Jasen