Lan*_*nce 5 jquery autocomplete
我正在使用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" />
Run Code Online (Sandbox Code Playgroud)
小智 16
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>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
10347 次 |
| 最近记录: |