Skip to content Skip to sidebar Skip to footer

Echo Js Onclick Fill Function Ajax Not Working

I have a search bar with AJAX, MySQL, PHP, and JS. The search bar gives live search results in a div in a list and works in that respect. My problem is the live search results in t

Solution 1:

you can use the ` sign instead of the single and double quotation for javascript.

Here you should just update the line 16 at ajax.php file like this.

echo"<li onclick='fill(`".$Result['Name']."`)'>".$Result['Name']." 

Complete code ajax.php file

<?php//Including Database configuration file.include"db.php";
//Getting value of "search" variable from "script.js".if (isset($_GET['search'])) {
//Search box value assigning to $Name variable.$Name = $_GET['search'];
//Search query.$Query = "SELECT Name FROM search WHERE Name LIKE '$Name%' LIMIT 5";
//Query execution$ExecQuery = MySQLi_query($con, $Query);
//Creating unordered list to display result.if ($ExecQuery->num_rows > 0) {
          echo"<ul>";
          while ($Result = MySQLi_fetch_array($ExecQuery)) {
            echo"<li onclick='fill(`".$Result['Name']."`)'>".$Result['Name']." 
     </li>";
     }
    echo"</ul>";
   }
  }
 die();
?>

JS codes.

//Getting value from "ajax.php".functionfill(Value) {
//Assigning value to "search" div in "index.php" file.
$('#search').val(Value);
//Hiding "display" div in "index.php" file.
$('#display').hide();
}
$(document).ready(function() {
//On pressing a key on "Search box" in "indexd.php" file. This function will be called.
$("#search").keyup(function() {
//Assigning search box value to javascript variable named as "name".
$('#display').hide();
$('#backspace').css("display", "none");
var name = $('#search').val();
//Validating, if "name" is empty.if (name == "") {
   //Assigning empty value to "display" div in "index.php" file.
   $('#backspace').css("display", "block");
}
//If name is not empty.else {
    //AJAX is called.
    $.ajax({
        //AJAX type is "GET".type: "GET",
        //Data will be sent to "ajax.php".url: "ajax.php",
        //Data, that will be sent to "ajax.php".data: {
            //Assigning value of "name" into "search" variable.search: name
        },
        //If result found, this funtion will be called.success: function(html) {
          if (html == '<ul><li>No Result Found!</li></ul>') {
             $('#no-results').css("display", "block");
          }else{
             //Assigning result to "display" div in "index.php" file.
             $("#display").html(html).show();
           }
        }
    });
   }
 });
});

Post a Comment for "Echo Js Onclick Fill Function Ajax Not Working"