溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

jQuery實(shí)現(xiàn)用戶輸入自動(dòng)完成功能

發(fā)布時(shí)間:2020-10-23 17:47:11 來源:腳本之家 閱讀:100 作者:sumer7310 欄目:web開發(fā)

利用jQuery UI中Auto-complete插件實(shí)現(xiàn)輸入自動(dòng)完成功能,大家在使用諸如淘寶、京東等電商平臺(tái)搜索商品時(shí),往往只要輸入商品的一些特殊字符,就可以顯示出和該字符相近的列表菜單,用戶使用鼠標(biāo)或者鍵盤方向鍵就可以快速選擇,實(shí)現(xiàn)了很好的用戶體驗(yàn)。

1.最簡(jiǎn)單的用戶輸入自動(dòng)完成

<!doctype html>
<html lang="en">
<head>
 <meta charset="utf-8">
 <title>jQuery UI Autocomplete - Default functionality</title>
 <link rel="stylesheet"  rel="external nofollow" >
 <script src="http://code.jquery.com/jquery-1.10.2.js"></script>
 <script src="http://code.jquery.com/ui/1.11.4/jquery-ui.js"></script>
 <script>
 $(function() {
 //定義并初始化字典庫(kù)數(shù)據(jù)源集合
 var availableTags = [
 "ActionScript",
 "AppleScript",
 "Asp",
 "BASIC",
 "C",
 "C++",
 "Clojure",
 "COBOL",
 "ColdFusion",
 "Erlang",
 "Fortran",
 "Groovy",
 "Haskell",
 "Java",
 "JavaScript",
 "Lisp",
 "Perl",
 "PHP",
 "Python",
 "Ruby",
 "Scala",
 "Scheme"
 ];
 //自動(dòng)完成插件函數(shù)
 $( "#tags" ).autocomplete({
 //自動(dòng)完成字典庫(kù)數(shù)據(jù)源
 source: availableTags
 });
 });
 </script>
</head>
<body>
<div class="ui-widget">
 <label for="tags">請(qǐng)輸入: </label>
 <input id="tags">
</div>
</body>
</html>

2 使用遠(yuǎn)程數(shù)據(jù)源自動(dòng)完成

Auto-complete插件不光可以實(shí)現(xiàn)本地?cái)?shù)據(jù)源的自動(dòng)完成,也可以讀取遠(yuǎn)程的數(shù)據(jù)源,列如實(shí)現(xiàn)從服務(wù)器端讀取數(shù)據(jù)源信息。

通過將服務(wù)器數(shù)據(jù)緩存到瀏覽器中,獲取的數(shù)據(jù)源首先保存在cache變量中。

 $(function() {
 //自定義緩存變量
 var cache = {};
 //自動(dòng)完成插件函數(shù)
 $("#tags").autocomplete({
 //定義用戶最少輸入的字符數(shù)
 minLenght: 2,
 source: function(request, response){//定義遠(yuǎn)程獲取數(shù)據(jù)源函數(shù)
 var term = request.term;//定義用戶請(qǐng)求信息變量
 if(term in cache) {//判斷請(qǐng)求數(shù)據(jù)是否存在緩存中
 response(cache[term]);//真,從緩存中讀取數(shù)據(jù)
 return;
 }
 $.getJSON('data.json', request, function(data, Status, xhr) {
 cache[term] = data.result;//緩存遠(yuǎn)程數(shù)據(jù)
 response(data.result);
 });
 }
 });
 });

以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時(shí)也希望多多支持億速云!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI