我希望这个问题有一个简单的答案,我只是没有看到。
我正在开发一个asp.net MVC 4应用程序。 基本上我想让用户编辑他们本来可以做的前一个条目(newsArticle)的内容(听起来很简单) 此条目包含日期,两个文本块,(标题和正文)和一个img。 这些条目对应于模型的属性,其中还包括ID,img名称和状态。 我已成功管理,以便在需要时输入,保存和检索所有数据。 但是,当我运行程序并尝试编辑上一个条目时,它只保存标题和正文文本,并删除那里的值,日期,img,img名称和状态。
这是否与视图中使用的文本框有关?为什么要保留这些价值而不保留其他价值。
要指出当我运行并选择一个条目时,所有数据都会正确显示,但是当我点击保存值时会被删除(日期,img名称,状态)
任何想法......
控制器...
public ActionResult Edit(int id)
{
String encodedBody;
NewsArticle newsArticle = _newsArticle.Get(id);
encodedBody = HttpUtility.HtmlDecode(newsArticle.Body.ToString());
newsArticle.Body = encodedBody;
return View(newsArticle);
}
// POST: /Article/Edit/5
[HttpPost]
public ActionResult Edit(NewsArticle newsArticle)
{
try
{
if (ModelState.IsValid)
{
db.Entry(newsArticle).State = EntityState.Modified;
db.SaveChanges();
return RedirectToAction("Index");
}
}
catch (System.Data.DataException)
{
//Log th error(add a variable name after DataExpection)
ModelState.AddModelError("", "Unable to save changes. Try again, and if the problem persists see your system administrator.");
}
return View(newsArticle);
}
查看.......
@using (Html.BeginForm("Edit", "Admin", FormMethod.Post, new { enctype = "multipart/form-data", @class = "form-horizontal", id = "newsEditForm"}))
{
@Html.ValidationSummary()
@Html.HiddenFor(model => model.ID)
<div class="control-group">
<label class="control-label">Posted on :</label>
<div class="controls">
<span class="text">@Model.DateCreated.Value.ToShortDateString()</span>
@*@Html.LabelFor(n => n.DateCreated)*@
</div>
</div>
<div class="control-group">
<label class="control-label">@Html.LabelFor(n => n.Title)</label>
<div class="controls">
@Html.TextBoxFor(n => n.Title, new { @class = "span4 m-wrap", rows = 1})
</div>
</div>
<div class="control-group">
<label class="control-label">@Html.LabelFor(n => n.Body)</label>
<div class="controls">
@Html.TextAreaFor(n => n.Body, new { @class = "span12 ckeditor m-wrap", rows = 4 })
</div>
</div>
<div class="control-group">
<label class="control-label">Selected Image </label>
<label class="controls">@Html.DisplayTextFor(model => model.ImageName)</label>
@* <div class="span4 blog-img blog-tag-data">
<div class="editor-field">
<input type="file" name="Article" id="ArticleImage"/>
</div>
</div>*@
</div>
<div class="form-actions">
<button type="submit" class="btn green" id="submitnews"><i class="icon-ok"></i>Submit</button>
@Html.ActionLink("Cancel", "ArticleList", "Admin", null, new { @class = "btn blue"})
@*<button type="button" class="btn blue" onclick="location.href='ArticleList','Admin'">Cancel</button>*@
</div>
}
答案 0 :(得分:0)
您的问题是您正在保存直接发布回数据库的新闻文章。发布的newsArticle包含图像,日期,img名称和状态的空条目,因为表单中不存在这些字段。出于这个和其他安全原因,您真的不应该将域模型传递回编辑。但是,这是对您的问题的快速解决方法
[HttpPost]
public ActionResult Edit(NewsArticle newsArticle)
{
try
{
if (ModelState.IsValid)
{
NewsArticle savedArticle= _newsArticle.Get(newsArticle.Id);
savedArticle.Body = newsArticle.Body
savedArticle.Title = newsArticle.Title
db.SaveChanges();
return RedirectToAction("Index");
}
}
catch (System.Data.DataException)
{
//Log th error(add a variable name after DataExpection)
ModelState.AddModelError("", "Unable to save changes. Try again, and if the problem persists see your system administrator.");
}
return View(newsArticle);
}