使用jquery+ajax+php实现搜索框的功能
首先是客户端
新建一个输入框
<input type="text" id="keyword" name="keyword" />
在输入框的下面创建一个div,先让他隐藏起来
<div id="searchBox" display: none"></div>
注:搜索框的定位可以使用绝对定位,定在输入框的下面,搜索按钮可以加在输入框的旁边,同样也是使用绝对定位
接下来是使用jq发送ajax请求(这里使用的是json格式的数据)
<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语句连接数据库,然后进行查询(这里使用的是PDO连接的方法)
<?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格式输出)
?>
注:服务端的函数最好写在别的页面,方便管理。
这样,搜索框的功能就能实现了。
微信扫描下方的二维码阅读本文
阅读剩余
版权声明:
标题:使用jquery+ajax+php实现搜索框的功能
作者:admin
链接:https://www.kmtky.com/126.html
文章版权归作者所有,未经允许请勿转载。
声明:仅供内部测试和技术交流使用,任何非法商业使用及商业利益冲突带来的法律纠纷,与本人无关,本人概不负责,请下载后24小时内删除,谢谢合作!如有侵权请于作者联系,尽快删除。
标题:使用jquery+ajax+php实现搜索框的功能
作者:admin
链接:https://www.kmtky.com/126.html
文章版权归作者所有,未经允许请勿转载。
声明:仅供内部测试和技术交流使用,任何非法商业使用及商业利益冲突带来的法律纠纷,与本人无关,本人概不负责,请下载后24小时内删除,谢谢合作!如有侵权请于作者联系,尽快删除。
THE END