私はasp.net MVC Webアプリケーションに取り組んでおり、次のメインビューがあります:-
@model TMS.ViewModels.VMJoin
//code goes here
<p>
@Ajax.ActionLink("Add Network Info", "CreateVMNetwork","VirtualMachine",
new { vmid = Model.VirtualMachine.TMSVirtualMachineID },
new AjaxOptions {
InsertionMode = InsertionMode.Replace,
UpdateTargetId = "AssignNetwork" ,
LoadingElementId = "progress"
}
)
</p>
<p><img src="~/Content/Ajax-loader-bar.gif" class="loadingimage" id="progress" /></p>
<div id ="AssignNetwork"></div>
<div id ="CreateEditNetwork"></div>
<table class="table table-striped table-bordered bootstrap-datatable datatable">
<thead>
<tr>
<th class="f"> IP Address </th>
<th class="f"> MAC Address </th>
</tr></thead>
<tbody id="networktable">
@foreach(var info in Model.VirtualMachine.Technology.TechnologyIPs){
<tr id="@info.ID">
<td> @info.IPAddress</td>
<td>@info.MACAddress</td>
<
</tr>
}
</tbody>
</table>
@section Scripts {
@Scripts.Render("~/bundles/jqueryval")
}
「Add Network Info」 ajax リンクをクリックすると、次の部分ビューがレンダリングされます。
@model TMS.ViewModels.AssignIps
@if (this.ViewContext.FormContext == null)
{
this.ViewContext.FormContext = new FormContext();
}
@using (Ajax.BeginForm("CreateVMNetwork", "VirtualMachine", new AjaxOptions
{
InsertionMode = InsertionMode.InsertAfter,
UpdateTargetId = "networktable",
LoadingElementId = "loadingimag",
HttpMethod= "POST",
OnSuccess="submitform"
}))
{
@Html.ValidationSummary(true)
@Html.HiddenFor(model=>model.TechnologyIP.TechnologyID)
@Html.AntiForgeryToken()
<div>
<span class="f">IP Address</span>
@Html.EditorFor(model => model.TechnologyIP.IPAddress)
@Html.ValidationMessageFor(model => model.TechnologyIP.IPAddress)
<input type="CheckBox" name="IsTMSIPUnique" value="true" @(Html.Raw(Model.IsTMSMACUnique ? "checked=\"checked\"" : "")) /> IP Unique. |
<span class="f"> MAC Address</span>
@Html.EditorFor(model => model.TechnologyIP.MACAddress)
@Html.ValidationMessageFor(model => model.TechnologyIP.MACAddress)
<input type="CheckBox" name="IsTMSMACUnique" value="true" @(Html.Raw(Model.IsTMSMACUnique ? "checked=\"checked\"" : "")) /> MAC Unique.
</div>
<input type="submit" value="Save" class="btn btn-primary"/>
}
@Scripts.Render("~/bundles/jqueryval")
しかし、部分ビュー内の [保存] ボタンをクリックすると、CreateVMNetwork Actino メソッドに 2 つのポスト リクエストが送信されます。問題は、 @Scripts.Render("~/bundles/jqueryval") をメインビューで1回、部分ビューで2回参照しているという事実に関連していると思います。スクリプトを 2 回参照しました。メイン ビューでは、ajax リンク用の ajax 機能が必要です。部分ビューでは、モデル データの注釈に従って部分ビュー フィールドを検証する必要があります。では、この問題をどのように克服できるかアドバイスできますか?
ありがとう