0

シナリオ:モデルからのデータを表示するドロップダウン、ボタン、およびhtmlテーブルがあります。以下はaspx&controllerのコードです

送信ボタンをクリックすると、データはポストバックなしで表示されますが、ドロップダウンリストとボタンが2回表示され、次のクリックで問題ありません。

どこでもHtml.RenderPartialを使用する必要がありますか?

//Controller
[AcceptVerbs(HttpVerbs.Post)]
        public ActionResult SimpleUpdate(int carMake)
        {
            ViewData["CarMake"] = new SelectList(_carDataContext.Makes.Select(m => new { ID = m.Id, Name = m.Name }), "ID", "Name", carMake);
            var carModel = _carDataContext.Models.Where(m => m.MakeId == carMake).ToList();
            return PartialView("carmodels", carModel);
        }

// in aspx
    <%using (Ajax.BeginForm("SimpleUpdate", new AjaxOptions { UpdateTargetId = "ajaxPanel" }))
          {%>
        <%=Html.DropDownList("CarMake")%>
        <br />
        <input type="submit" value="SimpleUpdate" />
        <%
            }%>
        <div id="ajaxPanel">
            <%
                if (Model != null)
                {
            %>
            <table>
                <tr>
                    <th>
                        Id
                    </th>
                    <th>
                        Name
                    </th>
                    <th>
                        MakeId
                    </th>
                </tr>
                <%

                    foreach (var item in Model)
                    {%>
                <tr>
                    <td>
                        <%=Html.Encode(item.Id)%>
                    </td>
                    <td>
                        <%=Html.Encode(item.Name)%>
                    </td>
                    <td>
                        <%=Html.Encode(item.MakeId)%>
                    </td>
                </tr>
                <%
                    }%>
            </table>
            <%}%>
        </div>
4

1 に答える 1

0

この場合、通常のビューではなく、部分的なビュー(ユーザーコントロールなど)を作成する必要があります。また、Html.RenderPartialを使用して、部分ビューをコントロールとしてメインビューに追加する必要があります。

于 2009-06-11T12:06:52.337 に答える