php文本框自动补全,PHP自动补全表单的两种方法
效果圖:
第一種:從數據庫中檢索之后補全
第二種:郵箱等純前端的補全
先說第二種,使用開源的插件,所以相對簡單。
github上面的項目 completer。
https://github.com/fengyuanchen/completer 做法特別容易,github上面有詳細的文檔。
一開始嘗試用這個來配上自己的后臺代碼,做成第一種的自動補全,搞了半天失敗了。可能本人js太差,改動太多的話,代碼很復雜,除非認真研究上面這個開源項目。
主要失敗在我在后臺數據庫找出來的完整的模糊查詢得到的數據,用上面的插件只能是補全在后面,沒有辦法完全替換輸入值。比如你輸入fafe,查到fafegeg, 但是下拉的表項中只能選到 fafefafegeg,因為是補全。
下面說說第一個怎么做,百度不到什么好的經驗介紹,就自己按自己的思路實現了:/** * php 返回模糊搜索的結果給自動完成 */ public function actionComplete($value,$blocked) { //將輸入的值與用戶名和郵箱進行模糊查詢 $result1 = User::find()->where(["blocked"=>$blocked])->andWhere(["type"=>$this->type])->andWhere(["like","username",$value])->all(); $result2 = User::find()->where(["blocked"=>$blocked])->andWhere(["type"=>$this->type])->andWhere(["like","email",$value])->all(); $string = ""; foreach ($result1 as $v) { $string = $string.$v->username.","; } foreach ($result2 as $v) { $string = $string."".$v->email.","; } $string = $string.""; //返回格式 類似username1,username2,email1, return $string ; }//前端
檢索//JS//autoComplete.css.auto_hidden { width:204px;border-top: 1px solid #333; border-bottom: 1px solid #333; border-left: 1px solid #333; border-right: 1px solid #333; position:absolute; display:none;}.auto_show { width:204px; border-top: 1px solid #333; border-bottom: 1px solid #333; border-left: 1px solid #333; border-right: 1px solid #333; position:absolute; z-index:9999; /* 設置對象的層疊順序 */ display:block;}.auto_onmouseover{ color:#ffffff; background-color:highlight; width:100%;}.auto_onmouseout{ color:#000000; width:100%; background-color:#ffffff;}//autoComplete.js/* 通用: 自動補全(仿百度搜索框) */var $ = function (id) { return "string" == typeof id ? document.getElementById(id) : id;}var Bind = function(object, fun) { return function() { return fun.apply(object, arguments); }}function AutoComplete(obj,autoObj,arr){ this.obj=$(obj); //輸入框 this.autoObj=$(autoObj);//DIV的根節點 this.value_arr=arr; //不要包含重復值 this.index=-1; //當前選中的DIV的索引 this.search_value=""; //保存當前搜索的字符}AutoComplete.prototype={ //初始化DIV的位置 init: function(){ this.autoObj.style.left = this.obj.offsetLeft + "px"; this.autoObj.style.top = this.obj.offsetTop + this.obj.offsetHeight + "px"; this.autoObj.style.width= this.obj.offsetWidth - 2 + "px";//減去邊框的長度2px }, //刪除自動完成需要的所有DIV deleteDIV: function(){ while(this.autoObj.hasChildNodes()){ this.autoObj.removeChild(this.autoObj.firstChild); } this.autoObj.className="auto_hidden"; }, //設置值 setValue: function(_this){ return function(){ _this.obj.value=this.seq; _this.autoObj.className="auto_hidden"; } }, //模擬鼠標移動至DIV時,DIV高亮 autoOnmouseover: function(_this,_div_index){ return function(){ _this.index=_div_index; var length = _this.autoObj.children.length; for(var j=0;jlength){ this.index=0; }else if(this.index==length){ this.obj.value=this.search_value; } this.changeClassname(length); } //光標鍵"↑" else if(event.keyCode==38){ this.index--; if(this.index以上所述是小編給大家介紹的PHP自動補全表單的兩種方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對網頁設計網站的支持!
總結
以上是生活随笔為你收集整理的php文本框自动补全,PHP自动补全表单的两种方法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: mcjava盗版联机_我的世界java版
- 下一篇: crontab 执行php脚本,为什么c