我正在使用jQuery / Ajax调用将部分视图附加到表中。页面加载时,将正确创建局部视图。但是,一旦使用尝试将另一个项目附加到表格,尽管使用了完全相同的局部视图,但格式化仍然不正确。
这是表格。加载后,项目将正确加载到页面上,如下图所示:
<table id="fixedRows">
<thead>
<tr>
<th>State Code</th>
<th>Agent ID</th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
@foreach (var item in Model.BankListAgentId)
{
if (!String.IsNullOrWhiteSpace(item.AgentId) && item.FixedOrVariable.Equals("F"))
{
@Html.EditorFor(model => item, "FixedPartialView")
}
}
</tbody>
</table>
<br />
<a href="#" class="addFixed">Add Another</a>
单击Add another
链接后,此jQuery / Ajax调用将被激活
<script type="text/javascript">
$(document).ready(function () {
$(".addFixed").click(function () {
//alert('test');
event.preventDefault();
$.ajax({
url: '@Url.Action("BlankFixedRow", "BankListMaster")',
cache: false,
success: function (html) { $("#fixedRows").append(html); }
});
});
$("#addVariable").click(function () {
event.preventDefault();
$.ajax({
url: '@Url.Action("BlankFixedRow", "BankListMaster")',
cache: false,
success: function (html) { $("#variableRows").append(html); }
});
});
});
</script>
jQuery从控制器调用此方法
public ViewResult BlankFixedRow()
{
SelectList tmpList = new SelectList(new[] { "AL", "AK", "AS", "AZ", "AR", "CA", "CO", "CT", "DE", "DC", "FM", "FL", "GA", "GU", "HI", "ID", "IL", "IN", "IA", "KS", "KY", "LA", "ME", "MH", "MD", "MA", "MI", "MN", "MS", "MO", "MT", "NE", "NV", "NH", "NJ", "NA", "NM", "NY", "NC", "ND", "MP", "OH", "OK", "OR", "PW", "PA", "PR", "RI", "SC", "SD", "TN", "TX", "UT", "US", "VT", "VI", "VA", "WA", "WV", "WI", "WY" });
ViewBag.StateCodeList = tmpList;
return View("FixedPartialView", new BankListAgentId());
}
调用此局部视图
编辑(有几个人注意到id
中缺少<tr>
标记,这只是此帖子的复制/粘贴错误,实际代码有id
标记)
@model Monet.Models.BankListAgentId
@{
Layout = null;
}
@using (Html.BeginCollectionItem("BankListAgentId"))
{
<tr id="item-@Model.AgentId">
<td>
@Html.DropDownListFor(model => model.StateCode,
(SelectList)ViewBag.StateCodeList, Model.StateCode)
</td>
<td>
@Html.EditorFor(model => model.AgentId)
@Html.ValidationMessageFor(model => model.AgentId)
</td>
<td>
<a href="#" class="deleteRow">delete</a>
</td>
@*<td><a href="#" onclick="$('#item-@Model.AgentId').parent().remove();" style="float:right;">Delete</a></td>*@
</tr>
}
这是与页面首次加载时调用的局部视图相同,这部分原因让我感到困惑的是,点击Add another
链接后的最终结果看起来像这样
修改
如果您点击Add another
链接两次,则结果为
修改
我尝试了以下jQuery sucess
命令但没有运气
success: function (html) { $("#fixedRows > tbody:last").append(html); }
success: function (html) { $("#fixedRows tr:last").after(html); }
success: function (html) { $("#fixedRows > tbody").append(html); }
以下是点击Add another
链接后呈现的HTML。我在其下方的表单中添加了开头<form>
标记,以表明无法找到新行。
<form action="/BankListMaster/Edit/11" method="post">
<fieldset>
<legend>Stat(s) Fixed</legend>
<table id="fixedRows">
<tr>
<th>State Code</th>
<th>Agent ID</th>
<th></th>
<th></th>
</tr>
<tr id="item-1164998320">
<td>
<select id="item_StateCode" name="item.StateCode"><option value="">HI</option>
<option>AL</option>
..
<option>WY</option>
</select>
</td>
<td>
<input class="text-box single-line" id="item_AgentId" name="item.AgentId" type="text" value="1164998320" />
<span class="field-validation-valid" data-valmsg-for="item.AgentId" data-valmsg-replace="true"></span>
</td>
<td>
<a href="#" class="deleteRow">delete</a>
</td>
</tr>
<tr id="item-1164998219">
<td>
<select id="item_StateCode" name="item.StateCode">
<option value="">HI</option>
<option>AL</option>
..
<option>WY</option>
</select>
</td>
<td>
<input class="text-box single-line" id="item_AgentId" name="item.AgentId" type="text" value="1164998219" />
<span class="field-validation-valid" data-valmsg-for="item.AgentId" data-valmsg-replace="true"></span>
</td>
<td>
<a href="#" class="deleteRow">delete</a>
</td>
</tr>
<tr id="item-0352926603">
<td>
<select id="item_StateCode" name="item.StateCode">
<option value="">GA</option>
<option>AL</option>
..
<option>WY</option>
</select>
</td>
<td>
<input class="text-box single-line" id="item_AgentId" name="item.AgentId" type="text" value="0352926603" />
<span class="field-validation-valid" data-valmsg-for="item.AgentId" data-valmsg-replace="true"></span>
</td>
<td>
<a href="#" class="deleteRow">delete</a>
</td>
</tr>
</table>
<br />
<a href="#" class="addFixed">Add Another</a>
</fieldset>
</form>
<a href="#" class="addFixed">Add Another</a>
<form action="/BankListMaster/Edit/11" method="post">
修改
以下是点击Add Another
链接后Chrome浏览器中表格的屏幕截图。如您所见,从表中提取的数据在相应的<tr>
标记中正确加载,但是空行(通过与其余部分相同的部分视图发送)没有任何相同的表元素。下面的屏幕截图显示了响应,但其中包含<tr>
标记
修改
我在console.log(html)
Ajax函数中添加了success
行,现在读取
success: function (html) {
console.log(html);
$("#fixedRows > tbody").append(html);
}
这是控制台输出(为便于阅读而编辑的状态)
<input type="hidden" name="BankListAgentId.index" autocomplete="off" value="3f7e0a92-8f20-4350-a188-0725919f9558" />
<tr>
<td>
<select id="BankListAgentId_3f7e0a92-8f20-4350-a188-0725919f9558__StateCode" name="BankListAgentId[3f7e0a92-8f20-4350-a188-0725919f9558].StateCode">
<option>AL</option>
..
<option>WY</option>
</select>
</td>
<td>
<input class="text-box single-line" id="BankListAgentId_3f7e0a92-8f20-4350-a188-0725919f9558__AgentId" name="BankListAgentId[3f7e0a92-8f20-4350-a188-0725919f9558].AgentId" type="text" value="" />
</td>
<td>
<a href="javascript:void(0)" class="deleteRow">delete</a>
</td>
</tr>
答案 0 :(得分:2)
多么彻底的噩梦...
首先,在Chrome的调试器中返回的HTML可以正常显示,但是当我点击页面的“查看源代码”时,除了最初加载的内容之外,我看不到任何内容。找到this post后,我发现这是正常的。然后我使用this Chrome add-on最终看到<tr>
和<td>
标记被删除了。只需在append语句中添加一个开始和结束标记,我就会将返回的项目附加到表中。
$(".addFixed").click(function () {
$.ajax({
url: '@Url.Action("BlankFixedRow", "BankListMaster")',
dataType: 'html',
cache: false,
success: function (html) {
$("#fixedRows > tbody").append('<tr>' + html + '</tr>');
}
});
});
答案 1 :(得分:1)
我在这看到一些事情。您在某些代码中引用了<tbody>
,但我在页面的任何位置都没有看到它。首先,我建议使用<thead>
和<tbody>
。在您的部分视图中,我看到<tr "item-@Model.AgentId">
应该有一个ID。
您还应该删除onclick处理程序和删除按钮,并将其与其余JavaScript一起放入。改为在删除链接上设置一个类。
对于不需要网址且仅用于附加JavaScript处理程序的链接,我建议使用href="javascript:void(0)"
,因为这会阻止浏览器对href="#"
执行任何特殊操作,因此您将成为能够删除对preventDefault()
的调用。
关于问题的根源,$("#fixedRows tbody").append(html)
是您想要的代码,因此无需尝试after()
。看起来你的HTML被剥离了。尝试在dataType
调用$.ajax()
。
html
属性