jquery.fastLiveFilter.js實現(xiàn)輸入自動過濾的方法
本文實例講述了jquery.fastLiveFilter.js實現(xiàn)輸入自動過濾的方法。分享給大家供大家參考。具體如下:
本效果是使用jquery.fastLiveFilter.js插件來實現(xiàn)的,類似于搜索框的輸入提示功能,實現(xiàn)對匹配項目的自動過濾功能,當(dāng)你輸入的時候,會根據(jù)輸入的字符智能匹配符合的內(nèi)容,自動列出來,提高人性化操作體驗,如果您對jquery.fastLiveFilter.js插件的用法感興趣,這是個很不錯的例子。
運行效果截圖如下:
具體代碼如下:
<!doctype html> <html> <head> <meta charset="utf-8"> <title>jQuery過濾器插件fastLiveFilter</title> <script src="jquery-1.6.2.min.js"></script> <script> //jquery.fastLiveFilter.js jQuery.fn.fastLiveFilter = function(list, options) { options = options || {}; list = jQuery(list); var input = this; var lastFilter = ''; var timeout = options.timeout || 0; var callback = options.callback || function() {}; var keyTimeout; var lis = list.children(); var len = lis.length; var oldDisplay = len > 0 ? lis[0].style.display : "block"; callback(len); input.change(function() { var filter = input.val().toLowerCase(); var li, innerText; var numShown = 0; for (var i = 0; i < len; i++) { li = lis[i]; innerText = !options.selector ? (li.textContent || li.innerText || "") : $(li).find(options.selector).text(); if (innerText.toLowerCase().indexOf(filter) >= 0) { if (li.style.display == "none") { li.style.display = oldDisplay; } numShown++; } else { if (li.style.display != "none") { li.style.display = "none"; } } } callback(numShown); return false; }).keydown(function() { clearTimeout(keyTimeout); keyTimeout = setTimeout(function() { if( input.val() === lastFilter ) return; lastFilter = input.val(); input.change(); }, timeout); }); return this; } </script> <script> $(function() { $('#search_input').fastLiveFilter('#search_list'); }); </script> <style type="text/css"> body { margin: 0px; background-color: #F6F6F6; } .jq22{ width: 600px; height: 500px; margin-left: auto; margin-right: auto; background-color: #FFFFFF; padding: 10px; } </style> </head> <body> <div class="jq22"> <input id="search_input" placeholder="輸入文字開始篩選"> <ul id="search_list"> <li>One</li> <li>Two</li> <li>Three</li> <li>One</li> <li>awo</li> <li>bhree</li> <li>cne</li> <li>dwo</li> <li>ehree</li> <li>fne</li> <li>gwo</li> <li>hhree</li> <li>ihree</li> </ul> </div> </body> </html>
希望本文所述對大家的jquery程序設(shè)計有所幫助。
- Javascript中關(guān)于Array.filter()的妙用詳解
- AngularJS中的過濾器filter用法完全解析
- JavaScript 數(shù)組some()和filter()的用法及區(qū)別
- JavaScript中利用Array filter() 方法壓縮稀疏數(shù)組
- JavaScript之filter_動力節(jié)點Java學(xué)院整理
- 詳解AngularJS中的filter過濾器用法
- Vue.js報錯Failed to resolve filter問題的解決方法
- AngularJS過濾器filter用法總結(jié)
- 詳解AngularJS Filter(過濾器)用法
- JavaScript中filter的用法實例分析
相關(guān)文章
關(guān)于setInterval、setTimeout在jQuery中的使用注意事項
最近碰到個問題,在使用jquery寫定時器時,總是會出現(xiàn)fn不存在的錯誤提示2011-09-09jquery.bgiframe.js在IE9下提示INVALID_CHARACTER_ERR錯誤
今天測試偶然發(fā)現(xiàn)jquery.bgiframe.js在IE9環(huán)境下提示錯誤,于是很是好奇,想辦法知道究竟,于是搜索了一下,現(xiàn)在與大家分享希望可以幫助你們2013-01-01jQuery函數(shù)的第二個參數(shù)獲取指定上下文中的DOM元素
這篇文章主要介紹了jQuery函數(shù)的第二個參數(shù)獲取指定上下文中的DOM元素,需要的朋友可以參考下2014-05-05JQUERY的AJAX請求緩存里的數(shù)據(jù)問題處理
這篇文章主要介紹了JQUERY的AJAX請求緩存里的數(shù)據(jù)問題處理的相關(guān)資料,需要的朋友可以參考下2016-02-02