使用jquery+ajax+php实现搜索框的功能

2 篇文章 0 订阅
1 篇文章 0 订阅

我们每天浏览网页都能见到搜索框


搜索框的原理:

客户端:输入要搜索的关键字于文本框,然后文本框将关键字获取,使用ajax发送请求到服务端,然后根据服务端返回来的信息显示到一个div中

服务端:接收传过来的数据,然后在数据库中搜索,再返回数据给客户端


首先是客户端

新建一个输入框

<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格式输出)

?>


注:服务端的函数最好写在别的页面,方便管理。


这样,搜索框的功能就能实现了。学习笔记,仅供参考~~





  • 4
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值