中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》
  • 首頁 > 
  • 教程 > 
  • 開發技術 > 
  • 如何在PHP中利用jQuery.autocomplete插件實現一個自動提示功能

如何在PHP中利用jQuery.autocomplete插件實現一個自動提示功能

發布時間:2020-12-19 16:12:22 來源:億速云 閱讀:229 作者:Leah 欄目:開發技術

如何在PHP中利用jQuery.autocomplete插件實現一個自動提示功能?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

XHTML

首先將jquery庫和相關ui插件,以及css導入。

復制代碼 代碼如下:


<link rel="stylesheet" href="jquery.ui.autocomplete.css"/>
<script type="text/javascript" src="js/jquery.js"></script>
<script type="text/javascript" src="ui/jquery.ui.core.js"></script>
<script type="text/javascript" src="ui/jquery.ui.widget.js"></script>
<script type="text/javascript" src="ui/jquery.ui.position.js"></script>
<script type="text/javascript" src="ui/jquery.ui.autocomplete.js"></script>

jQuery ui 插件可以在官網上下載:
接著在body中寫一個輸入框:

復制代碼 代碼如下:


<input type="text" id="key" name="key" />

jQuery

復制代碼 代碼如下:


$(function(){
    $("#key").autocomplete({
        source: "search.php",
        minLength: 2
    });
});

一看就明白,調用autocomplete插件,數據源來自search.php,當用戶輸入1個字符的時候就調用數據源。autocomplte插件提供了幾個可配置的參數:
disabled:是否在頁面加載后不可用,默認為false,這個沒必要設置成true,沒有多大意義。
appendTo:輸入時下拉的提示框追加元素,默認為"body"。
autoFocus:默認為false,當設置成true時,下拉提示框第一個將會是被選中的狀態。
delay:加載數據時的延遲時間,默認為300,單位毫秒。
minLength:輸入多少個字符時就會出現下拉提示,默認為1。
position:定義下拉提示框的位置。
source:定義數據源,數據源必須是json形式的,本例是通過請求search.php獲取的數據源。
autocomplete還提供了許多事件和方法,詳情請查看其官網:

PHP

調用了autocomplete插件后,還并沒有提示效果,別著急,因為需要調用數據源。
首先我們需要一張表,并要往表中添加適量數據,表的結構如下:

CREATE TABLE `art` ( 
 `id` int(11) NOT NULL auto_increment, 
 `title` varchar(100) NOT NULL, 
 PRIMARY KEY (`id`) 
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ;

 
請自行建表,并往表art中添加數據。

search.php實現了連接Mysql數據庫,并根據前端用戶的輸入,查詢并獲取數據表中相匹配的內容,然后以JSON形式輸出。

include_once("connect.php"); //連接數據庫 
 
$q = strtolower($_GET["term"]); //獲取用戶輸入的內容 
$query=mysql_query("select * from art where title like '$q%' limit 0,10"); 
//查詢數據庫,并將結果集組成數組 
while ($row=mysql_fetch_array($query)) { 
  $result[] = array( 
    'id' => $row['id'], 
    'label' => $row['title'] 
  ); 
} 
echo json_encode($result); //輸出JSON數據

最后輸出的JSON數據格式為:

復制代碼 代碼如下:


[{"id":"3","title":"\u4f7f\u7528CSS\u548cjQuery\u5236\u4f5c\u6f02\u4eae\u7684\u4e0b
\u62c9\u9009\u9879\u83dc\u5355"},
{"id":"4","title":"\u4f7f\u7528jQuery\u548cCSS\u63a7\u5236\u9875\u9762\u6253\u5370
\u533a\u57df"}]

這時,再測試下輸入,是不是看到你要的效果了呢?
最后,值得一提的是,autocomplete插件在firefox上有一個輸入BUG,輸入后并不能提示,需要向前空格再退格才有提示。網上有很多同學給出了解決方案,但是目前最新的autocomplete插件代碼貌視進行了重構,我的解決方法是,在133行中加入如下代碼:

.bind("input.autocomplete",function(){ 
  //修復FF不支持中文bug 
  self.search(self.item); 
});

看完上述內容,你們掌握如何在PHP中利用jQuery.autocomplete插件實現一個自動提示功能的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

齐河县| 同心县| 莱州市| 宜兴市| 如皋市| 逊克县| 湟源县| 临湘市| 北川| 宜昌市| 南皮县| 安西县| 霍邱县| 轮台县| 句容市| 巴中市| 南宫市| 原平市| 万载县| 岳阳县| 福建省| 扬中市| 沂南县| 扎赉特旗| 青田县| 天长市| 清流县| 五常市| 平遥县| 子洲县| 长沙市| 翼城县| 黄骅市| 泸水县| 富锦市| 临泽县| 沂南县| 岗巴县| 阳泉市| 宁津县| 襄城县|