这是模型example.cs
namespace View_Partial_Editor.Models
{
public class ExampleView
{
...
public string Field1 { get; set; }
public string Field2 { get; set; }
public string Field3 { get; set; }
public string Field4 { get; set; }
public string Field5 { get; set; }
...
}
}
我有这样的看法 example.cshtml
:
@model View_Partial_Editor.Models.ExampleView
@{Html.RenderPartial("EditExample",Model);}
@Html.TextBoxFor(m => m.Field1)
然后我有这个 partialView EditExample.cshtml
:
@model View_Partial_Editor.Models.ExampleView
@Html.HiddenFor(m => m.Field1)
@using (Ajax.BeginForm("EditExample", new AjaxOptions { InsertionMode = InsertionMode.Replace, UpdateTargetId = "partial" }))
{
<div>
@Html.EditorFor(m => m, "Editor", null)
</div>
<p>
<input id="buttona" type="submit" value="Save" />
</p>
}
我有这个控制器ExampleController
:
namespace View_Partial_Editor.Controllers
{
public class ExampleController : Controller
{
//
// GET: /Example/
public ActionResult Example()
{
return View();
}
[HttpPost]
public ActionResult EditExample(ExampleView example)
{
example.Field1 ="7";
return View("Example", example);
}
}
}
这是在部分中调用的编辑器editor.cshtml
@model View_Partial_Editor.Models.ExampleView
<div class="editor-label">
@Html.LabelFor(m => m.Field1 )
</div>
<div class="editor-field">
@Html.EditorFor(m => m.Field1)
@Html.ValidationMessageFor(m => m.Field1)
</div>
<div class="editor-label">
@Html.LabelFor(m => m.Field2)
</div>
<div class="editor-field">
@Html.EditorFor(m => m.Field2)
@Html.ValidationMessageFor(m => m.Field2)
</div>
我的问题是我想在ajax调用中修改控制器中模型的数据,并将修改后的模型返回给exampleView
.但是当ajax调用完成时,我在控制器中更改的值在模型中没有改变
编辑:我想要的是将调用发送到 ajax 方法,在数据库中保存一些内容,然后修改模型,并且在示例视图中我希望该模型具有更改。
此时,如果我用ajax的结果替换部分视图,示例视图中的模型不会被修改。另一种方法是替换完整示例视图,因此模型在那里接收,但我必须通过许多使用 Html.HiddenFor 的字段,可以在不替换视图的情况下实现这一点,只返回带有更改的模型