日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

php文本框自动补全,PHP自动补全表单的两种方法

發布時間:2024/7/5 php 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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自动补全表单的两种方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。