视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
PHP结合AJAX实现搜索提示功能
2020-11-03 12:30:41 责编:小采
文档


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

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

示例代码

客户端:

<script> 
 $(document).ready(function(){ 
 var xhr=null; 
 $('input[name="keyword"]').keyup(function() { 
 if(xhr){ 
 xhr.abort();//如果存在ajax的请求,就放弃请求 
 } 
 var inputText= $.trim(this.value); 
 if(inputText!=""){//检测键盘输入的内容是否为空,为空就不发出请求 
 xhr=$.ajax({ 
 type: 'GET', 
 url: 'service/suggestion.php', 
 cache:false,//不从浏览器缓存中加载请求信息 
 data: "keyword=" + inputText,//向服务器端发送的数据 
 dataType: 'json',//服务器返回数据的类型为json 
 success: function (json) { 
 if (json.length != 0) {//检测返回的结果是否为空 
 var lists = "<ul>"; 
 $.each(json, function () { 
 lists += "<li>"+this.pd_name+"</li>";//遍历出每一条返回的数据 
 }); 
 lists+="</ul>"; 
 
 $("#searchBox").html(lists).show();//将搜索到的结果展示出来 
 
 $("li").click(function(){ 
 $("#keyword").val($(this).text());//点击某个li就会获取当前的值 
 $("#searchBox").hide(); 
 }) 
 
 } else { 
 $("#searchBox").hide(); 
 } 
 
 
 } 
 
 }); 
 }else{ 
 $("#searchBox").hide();//没有查询结果就隐藏搜索框 
 } 
 }).blur(function(){ 
 $("#searchBox").hide();//输入框失去焦点的时候就隐藏搜索框 
 }); 
 
 }); 
</script>

服务端:

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

推荐教程:《PHP教程》

下载本文
显示全文
专题