我正在使用jquery的自动完成功能,并且工作正常,只是当我从下拉列表中选择某项时,输入字段中填充的是值而不是标签。
我的代码如下:
<?php
$query = mysql_query("SELECT users.* FROM users JOIN peers ON peers.peer = users.user_id WHERE peers.user_id = '".$_SESSION['id']."'")or die(mysql_error());
$count = mysql_num_rows($query);
$i = 0;
while($row = mysql_fetch_assoc($query))
{
$first[$i] = $row['first_name'];
$last[$i] = $row['last_name'];
$user_id[$i] = $row['user_id'];
$i++;
}
$data = "";
for($i=0;$i<$count;$i++)
{
if($i != ($count-1))
{
$data .= '{ value: '.$user_id[$i].', label: "'.$first[$i].' '.$last[$i].'" }, ';
} else
{
$data .= '{ value: '.$user_id[$i].', label: "'.$first[$i].' '.$last[$i].'" }';
}
}
?>
<script type="text/javascript">
$("#auto").autocomplete({
source: data,
select: function(event, ui)
{
var id = ui.item.value;
var name = ui.item.label;
}
});
</script>
<input type="text" value="Enter a connection's name" id="auto" />
最佳答案
select事件的默认行为是使用ui.item.value更新输入。此代码在事件处理程序之后运行。
只需返回false或调用event.preventDefault()即可防止这种情况的发生。试试这个,
<script type="text/javascript">
$("#auto").autocomplete({
source: data,
select: function(event, ui)
{
var id = ui.item.value;
var name = ui.item.label;
$("#auto").val(name);
return false;
},
focus: function(event, ui){
return false;
}
});
</script>