У меня есть автозаполнение ajax, где оно возвращает полное имя пользователя. Однако, когда бывают случаи, когда некоторые имена или значения одинаковы, он не возвращает правильное значение. Скорее, он возвращает первое значение в раскрывающемся списке. Даже если он имеет 4 одинаковых входа, он все равно возвращает первое значение.Ajax autocomplete не возвращает правильное значение
Когда я нажимаю Stannis Аррен Баратеон, он возвращает Stannis Targaryen Баратеон.
Вот мой PHP код (SQL/PHP код; ad.php):
<?php
include('config.php');
if($_POST)
{
if($_POST['search_keyword'])
{
$similar = mysql_real_escape_string($_POST['search_keyword']);
$result=mysqli_query($conn, "SELECT * FROM person WHERE (firstName like '" . $_POST["search_keyword"] . "%' OR lastName like '" . $_POST["search_keyword"] . "%') AND residentOrNot = 'Yes' ");
if (mysqli_num_rows($result) > 0) {
while($row=mysqli_fetch_array($result))
{
//$name = $row['fullname'];
//$copiedname = $row['fullname'];
//$b_name= '<strong>'.$similar.'</strong>';
//$final_name = str_ireplace($similar, $b_name, $name);
?>
<div class="show" align="left">
<span class="returnName"><?php echo $row["firstName"].' '.$row["middleName"].' '.$row["lastName"]; ?></span>
<span class="returnID" style="display:none"><?php echo $row['idPerson'];?></span>
</div>
<?php
}
}
else {
?>
<div class="show" align="left">
<span class="returnMessage">No matching records found.</span>
</div>
<?php
}
}
mysqli_close($conn);
}
?>
HTML формы ввода:
<form method="post" action="try.php" name="try">
<div class='web'>
<input type="text" class="search_keyword" id="search_keyword_id" placeholder="Search" />
<input type="hidden" name="resID" id="resID"/>
<div id="result"></div>
<input type="submit" name="try" value="Submit">
</div>
AJAX/JS/JQuery КОД (я думаю, что именно здесь возникает проблема):
<script type="text/javascript">
$(function(){
$(".search_keyword").keyup(function()
{
var search_keyword_value = $(this).val();
var dataString = 'search_keyword='+ search_keyword_value;
if(search_keyword_value!='')
{
$.ajax({
type: "POST",
url: "ad.php",
data: dataString,
cache: false,
success: function(html)
{
$("#result").html(html).show();
}
});
}
return false;
});
jQuery("#result").on("click", function(e)
{
/*var $clicked = $(e.target);
var $name = $clicked.find('.returnName').html();
var decoded = $("<div/>").html($name).text();
$('#search_keyword_id').val(decoded);
var $clicked = $(e.target);
var $id = $clicked.find('.returnID').html();
var id = $("<div/>").html($id).text();
$('#resID').val(id);
*/
$name = $('span.returnName',this).html();
$name = $("<div/>").html($name).text().toString();
$('#search_keyword_id').val($name);
$id = $('span.returnID',this).html();
$id = $("<div/>").html($id).text().toString();
$('#resID').val($id);
});
jQuery(document).on("click", function(e) {
var $clicked = $(e.target);
if (! $clicked.hasClass("search_keyword")){
jQuery("#result").hide();
}
});
});
</script>
Это действительно возвращает первое значение, даже если я нажимаю второе или третье или четвертое значение. Где я ошибся в своем коде? Пожалуйста, помогите мне. Спасибо огромное!
Вы пытаетесь изобрести колесо .. . Кажется, что проблема в '(" #result ").on («click» 'method ... проверьте это :) – Hackerman
Я просмотрел его. Но я действительно не могу это исправить ... –
Просто для тестирования; вместо этого вы можете заменить вместо этого свой код следующим образом: 'jQuery (« # result »). on (функция« click »,«. returnName »(e) { $ name = $ (this) .html(); $ ('# resID'). val ($ name); }); ' – Hackerman