PHP와 AJAX를 결합하여 검색 프롬프트 기능 구현
먼저 입력 상자를 만든 다음 입력 상자의 키업 이벤트를 수신합니다. 이벤트가 트리거되면 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 튜토리얼"
위 내용은 PHP와 AJAX를 결합하여 검색 프롬프트 기능 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!