Html.EditorFor()から予期しない動作が発生します。
私はこのコントローラーを持っています:
[HandleError]
public class HomeController : Controller
{
[AcceptVerbs(HttpVerbs.Get)]
public ActionResult Lister()
{
string[] values = { "Hello", "world", "!!!" };
return View(values);
}
[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Lister(string[] values)
{
string[] newValues = { "Some", "other", "values" };
return View(newValues);
}
}
そして、これはこれらの両方のために働くことを意図している私の見解です:
<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<string[]>" %>
<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
Lister
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
<h2>Lister</h2>
<% using (Html.BeginForm()) { %>
<% foreach (string value in Model) { %>
<%= value %><br />
<% } %>
<%= Html.EditorForModel() %>
<input type="submit" value="Append Dashes" />
<% } %>
</asp:Content>
問題は、ポストバックがビューから作成された場合、正しいアクションが実行されても、foreach
ループが新しい値を出力している間、テキストボックスには元のhelloworldデータが表示されることです。ASP.NETの何かが、テキストボックスの更新からモデル値をオーバーライドしていて、同じ古い値を表示しているように感じます。
IEnumerableを使用してEditorForを学習しようとしたときに、この問題が見つかりました。