PHP结合AJAX实现搜索提示功能

 4804

PHP结合AJAX实现搜索提示功能,有时候我们需要为搜索框加上自动完成功能,也就是搜索提示。


PHP结合AJAX实现搜索提示功能


方法如下:

首先将创建一个输入框;然后监听输入框的keyup事件,当事件触发时,使用AJAX请求将输入的内容发送给PHP;接着PHP根据输入的内容进行数据查找并返回;最后将返回的数据进行渲染即可。


JS代码:

  1. $(document).ready(function(){  
  2.     var xhr=null;  
  3.     $('input[name="keyword"]').keyup(function() {  
  4.         if(xhr){  
  5.             xhr.abort();//如果存在ajax的请求,就放弃请求  
  6.         }
  7.         var inputText= $.trim(this.value);  
  8.         if(inputText!=""){
  9.             //检测键盘输入的内容是否为空,为空就不发出请求  
  10.             xhr=$.ajax({  
  11.                 type: 'GET',  
  12.                 url: 'service/suggestion.php',  
  13.                 cache:false,//不从浏览器缓存中加载请求信息  
  14.                 data: "keyword=" + inputText,//向服务器端发送的数据  
  15.                 dataType: 'json',//服务器返回数据的类型为json  
  16.                 success: function (json) {  
  17.                     if (json.length != 0) {//检测返回的结果是否为空  
  18.                         var lists = "<ul>";  
  19.                         $.each(json, function () {  
  20.                             lists += "<li>"+this.pd_name+"</li>";//遍历出每一条返回的数据  
  21.                         });  
  22.                         lists+="</ul>";
  23.                         $("#searchBox").html(lists).show();//将搜索到的结果展示出来
  24.                         $("li").click(function(){
  25.                             $("#keyword").val($(this).text());//点击某个li就会获取当前的值
  26.                             $("#searchBox").hide();  
  27.                         })
  28.                     } else {
  29.                         $("#searchBox").hide();
  30.                     }
  31.                 }  
  32.             });
  33.         }else{
  34.             $("#searchBox").hide();//没有查询结果就隐藏搜索框
  35.         }
  36.     }).blur(function(){
  37.         $("#searchBox").hide();//输入框失去焦点的时候就隐藏搜索框
  38.     });
  39. });

服务端:

  1. <?php  
  2. session_start();
  3. function connectDb(){//连接数据库的函数  
  4.     $db_server="localhost";
  5.     $db_name="test";//数据库的名称
  6.     $db_user="root";//数据库的用户名,不同的用户权限不同
  7.     $db_pwd="";//数据库的密码
  8.     $dsn="mysql:host=$db_server;dbname=$db_name;charset=utf8";//使用PDO的方法连接数据库 
  9.     try{
  10.         $connect=new PDO($dsn,$db_user,$db_pwd,array(PDO::ATTR_PERSISTENT=>true));//如果需要数据库长连接,需要最后加一个参数
  11.     }
  12.     catch(PDOException $e){
  13.         exit('数据库连接失败');
  14.     }
  15.     return $connect;
  16. } 
  17. function test($keyword){//从数据库中查找关键字的函数
  18.     $db=connectDb();
  19.     $result=$db->prepare("select 字段名 from 数据库名字 where 字段名 like ?"); 
  20.     $result->bindParam(1,$keyword);//第一个问号的值
  21.     $result=>execute;
  22.     return $result->fetchAll(PDO::FETCH_ASSOC);
  23. }
  24. $keyword=$_GET['keyword'];//获取输入框的内容
  25. $suggestion=test($keyword);
  26. echo json_encode($suggestion);//输出查询的结果(json格式输出)
  27. ?>

以上就是PHP结合AJAX实现搜索提示功能的详细内容,具体应用到项目中还需要跟母实际情况改写,这里仅仅一共一种思路。大家可以根据以上方法进行拓展!



TAG标签:
本文网址:https://www.zztuku.com/index.php/detail-7777.html
站长图库 - PHP结合AJAX实现搜索提示功能
申明:如有侵犯,请 联系我们 删除。

评论(0)条

您还没有登录,请 登录 后发表评论!

提示:请勿发布广告垃圾评论,否则封号处理!!

    编辑推荐

    WordPress网站优化方法