我有一个jquery自动完成字段正常工作,然后是日期输入字段。每当用户从自动完成列表中选择一个项目时,它会正确选择该项目并触发结果(),但它也会在我的日期字段中创建“附带损害”,并将所选自动完成项目的ID插入其中。这是一个例子,但我也注意到它在其他场合,有时如果其他输入字段在自动完成字段之前或后面,则无关紧要。此外,如果有3个(任意数量)其他字段,则所有三个字段都将插入自动完成项目ID。
这是不受欢迎的行为,我需要摆脱它。 任何人吗?
以下是代码:
$("#Clients").focus().autocomplete('<%=Url.Action("GetClients", "Client") %>', {
dataType: 'json',
parse: function(data) {
var rows = new Array();
for (var i = 0; i < data.length; i++) {
rows[i] = { data: data[i], value: data[i].ClientName, result: data[i].ClientName };
}
return rows;
},
formatItem: function(row, i, n) {
return row.ClientName;
},
width: 300,
minChars: 0,
max: 0,
delay: 50,
cacheLength: 10,
selectFirst: true,
selectOnly: true,
mustMatch: true
});
$("#Clients").result(function(event, data, formatted) {
if (data) {
$(this).parent().next().find("input").val(data["client_id"]);
if (data["ClientName"] && data["client_address1"] && data["client_postcode"] && data["client_postname"]) {
$("#ClientDetails").html(
"<li class=\"clientNumber\">Client Id: " + data["client_ClientNumber"] + "</li>" +
"<li>" + data["ClientName"] + "</li>" +
"<li>" + data["client_address1"] + "</li>" +
"<li>" + data["client_postcode"] + data["client_postname"] + "</li>"
);
}
else {
$("#ClientDetails").html(
"<li class=\"clientNumber\">Client Id: " + data["client_ClientNumber"] + "</li>" +
"<li>" + data["ClientName"] + "</li>");
}
}
});
答案 0 :(得分:0)
对我来说这行
$(this).parent().next().find("input").val(data["client_id"]);
看起来有点可疑。