ホームページ >バックエンド開発 >PHPチュートリアル >php、jQueryオートコンプリート
長い間苦労してやっと見つけました。
1. jquery-1.3.2.min.js が必要です。 )、 jquery.autocomplete.js 、 jquery.autocomplete.css の 3 つのファイル。どこ? google..
2. フロントエンド ページの js は次のとおりです:
user.js
$(function() { $("#u_name").blur(function(){ //查询user表,检查是否存在,存在,则将用户信息显示;不存在,刚更新隐藏域,标识为new //如果是新添加的用户,保存到数据库。 var u_name = $.trim($("#u_name").val()); if(u_name != ""){ $.ajax({ url:"finduser.php", type:"get", dataType:"json", data:{username:$("#u_name").val(),u:"definate_text"}, error:function(){ sessionTimeOut(); }, success:function(data){ if(data!=null){ $("#u_mail").attr("value",data.mail); $("#u_phone").attr("value",data.phone); $("#u_office").attr("value",data.office); $("#existflag").attr("value",data.existflag); } } }); } }); //here $("#u_name").autocomplete("finduser.php", { cacheLength:0, selectFirst:true, matchSubset:false, multiple: false, width:135, max:20, dataType: 'json', extraParams: {username:function(){return $("#u_name").val();},u:"indefinate_text"}, parse: function(data) { var rows = []; if(""!=data){ for(var i=0; i<data.length; i++){ rows[rows.length] = {data:data[i],result:data[i]}; } } return rows; } }); $(document).keydown(function(event){ if(event.keyCode==13){ if((document.activeElement.id=="u_name") && ($.trim($("#u_name").val()).length>1)){ $("#u_name").blur(); } } });});
3. バックエンド PHP 部分:
finduser.php
<?php$flag= $_GET['u'];if($flag=='definate_text'){ $sql = "select * from $users_table where user_name = '".$_GET['username']."'"; $autoresult = $db->query($sql); $autorow = $db->fetch_array($autoresult); $autoemail = $autorow[email]; $autooffice = $autorow[office]; $autophone = $autorow[phone]; $existflag=1; if ($autorow==false){ $existflag=0;//0不存在,1存在。 } $array=array('mail'=>"$autoemail",'office'=>"$autooffice",'phone'=>"$autophone",'existflag'=>"$existflag"); echo json_encode($array);}if($flag=='indefinate_text'){ $sql = "select user_name from $users_table where user_name like '".$_GET['username']."%'"; $autoresult = $db->query($sql); //$db是创建好的mysql_connect,query方法其实调用的是mysql_query $array=array(); while($row = $db->fetch_array($autoresult)){ array_push($array,array($row['user_name'])); } echo json_encode($array);}?>
4. -endページには入力ボックスがあり、主に上記のPHPリターンとJS処理を行います。