2016-09-27 77 views
1

每當我嘗試編輯我在ASP.NET MVC項目中創建的記錄時,當我單擊「保存」時,字段都是無效的。當在視圖中編輯記錄時,數據庫表中的字段無效

這裏是我的控制器,我的編輯得到了部分代碼和崗位:

查看控制器:

// GET: Reviews/Edit/5 
    public ActionResult Edit(int? id) 
    { 
     if (id == null) 
     { 
      return new HttpStatusCodeResult(HttpStatusCode.BadRequest); 
     } 
     Review review = db.Reviews.Find(id); 
     if (review == null) 
     { 
      return HttpNotFound(); 
     } 
    ViewBag.ReviewID = new SelectList(db.Reviews, "ReviewID", "Rating", review.ReviewID); 
    return View(review); 
} 


// POST: Reviews/Edit/5 
// To protect from overposting attacks, please enable the specific properties you want to bind to, for 
// more details see http://go.microsoft.com/fwlink/?LinkId=317598. 
[HttpPost] 
[ValidateAntiForgeryToken] 
public ActionResult Edit([Bind(Include = "ReviewID,Username,WellnessService,Rating,Feedback,Date")] Review review) 
{ 
    if (ModelState.IsValid) 
    { 
     db.Entry(review).State = EntityState.Modified; 
     db.SaveChanges(); 
     return RedirectToAction("ReviewEdit"); 
    } 
    ViewBag.ReviewID = new SelectList(db.Reviews, "ReviewID", "Rating", review.ReviewID); 
    return View(review); 
} 

這裏是我的觀點叫做編輯代碼:

@using (Html.BeginForm()) 
     { 
       @Html.AntiForgeryToken() 
      <div class="form-horizontal"> 
       <h4>@Html.DisplayFor(model => model.WellnessService)</h4> 
       <hr /> 
       @Html.ValidationSummary(true, "", new { @class = "text-danger" }) 
       @Html.HiddenFor(model => model.ReviewID) 


       <div class="form-group"> 
        @Html.LabelFor(model => model.Rating, htmlAttributes: new { @class = "control-label col-md-2" }) 
        <div class="col-md-10" align="left"> 
         @{ 
          List<SelectListItem> listItems = new List<SelectListItem>(); 
          listItems.Add(new SelectListItem { Text = "1", Value = "1" }); 
          listItems.Add(new SelectListItem { Text = "2", Value = "2" }); 
          listItems.Add(new SelectListItem { Text = "3", Value = "3" }); 
          listItems.Add(new SelectListItem { Text = "4", Value = "4" }); 
          listItems.Add(new SelectListItem { Text = "5", Value = "5" }); 
          listItems.Add(new SelectListItem { Text = "6", Value = "6" }); 
          listItems.Add(new SelectListItem { Text = "7", Value = "7" }); 
         } 

         @Html.DropDownListFor(model => model.Rating, listItems, "Please choose value") 
         @Html.ValidationMessageFor(model => model.Rating, "", new { @class = "text-danger" }) 
        </div> 
       </div> 

       <div class="form-group"> 
        @Html.LabelFor(model => model.Feedback, htmlAttributes: new { @class = "control-label col-md-2" }) 
        <div class="col-md-10"> 
         @Html.TextAreaFor(model => model.Feedback, new { htmlAttributes = new { @class = "form-control" } }) 
         @Html.ValidationMessageFor(model => model.Feedback, "", new { @class = "text-danger" }) 
        </div> 
       </div> 

       <div class="form-group"> 
        <div class="col-md-offset-2 col-md-10"> 
         <input type="submit" value="Save" class="btn btn-default" /> 
        </div> 
       </div> 
      </div> 
          } 

     <div> 
      @Html.ActionLink("Back to My Reviews", "ReviewEdit", new { @class = "btn btn-success btn-lg" }) 
     </div> 

     @section Scripts { 
      @Scripts.Render("~/bundles/jqueryval") 
     } 

幫助將不勝感激

在此先感謝

+0

您可以在控制器方法後的Edit()中放置一個斷點,並查看「review」的內容是什麼?它也是空嗎? –

回答

1

沒有一個dev電腦來檢查這個,但你確定審查中有數據。如果有,你能確定下面的行可以工作嗎?

db.Entry(review).State = EntityState.Modified; 

您是否需要將評論附加到上下文中?

如果你暫時做某件事會發生什麼;

if (ModelState.IsValid) 
{ 
    var foo = db.Entry.Where(x=>x.reviewId == review.reviewId).First(); 
    // then manually set all the parameters 

    db.SaveChanges(); 
    return RedirectToAction("ReviewEdit"); 
} 

它不是優雅,但其是否正常工作,你的數據被更新,至少你知道它要連接的對象上下文的方式。 稍後我會嘗試獲取更好的示例,以便能夠訪問開發工作站。

相關問題