如何使用jquery执行以下操作?
我有一个包含三行和一个标题行的表。这样的事情: 当用户在“StudentId”字段中输入数据时,使用jquery-Ajax从数据库填充“StudentFirstName”和“StudentLastName”。我想要实现的是,一旦在第一行文本框中输入studentId,我想克隆第一行并将其作为第二行追加,然后从第一行清除数据。
她是我的桌面结构:
<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl<dynamic>" %>
<%@ Import Namespace="MyModel.Model" %>
<div>
<table id="MyTableHeaders">
<tr>
<th>
StudentId
</th>
<th>
StudentFirstName
</th>
<th>
StudentLastName
</th>
</tr>
</table>
</div>
<div>
<table id="MyTableData">
<tr>
<td>
<input name="StudentId"/>
</td>
<td>
<input name="StudentFirstName"/>
</td>
<td>
<input name="StudentLastName"/>
</td>
</tr>
</table>
</div>
这是我的jquery:
$('input[name="StudentId"]').focusout(function (e) {
e.preventDefault();
var link = '/Student/DisplayStudentDetails';
$.ajax({
type: 'POST',
url: link,
data: { id: $('input[name="StudentId"]').val() },
dataType: 'json',
success: function (result) {
$('input[name="StudentFirstName"]').val(result.FirstName);
$('input[name="StudentLastName"]').val(result.LastName);
$("#MyTableData tr:first").clone().appendTo("#MyTableData");
$("#MyTableData tr:first").find("input").attr("value", "").blur();
},
error: function (result) {
alert("Failed")
}
});
});
我正在努力清理第一行的数据并将数据保存在克隆的行中。使用我的代码,它会清除所有行。
另外,我注意到克隆的行具有相同的字段名称,因此它将更新所有克隆的“StudentFirstName”和“StudentLastName”字段,并在第一行输入studentId。我该怎么做呢?
任何帮助都将不胜感激。
答案 0 :(得分:1)
success: function (result) {
var clone = $("#MyTableData tr:first").clone();
clone.find('input[name="StudentId"]').val(result.FirstName);
clone.find('input[name="StudentFirstName"]').val(result.FirstName);
clone.find('input[name="StudentLastName"]').val(result.LastName);
$("#MyTableData ").append(clone);
},
-edit -
但是,当我过去尝试过这样的任务时,我已经创建了模板行。 已经存在但具有display:none的行。这样,如果你的表没有值,你总是可以知道模板行存在。
CNC中 如果你想在开头添加新行,你可以使用prepend而不是append。 或者第二行是$(“#MyTableData tr”)。first()。after(clone)