亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

基于javascript實現的搜索時自動提示功能

2019-11-20 13:35:45
字體:
來源:轉載
供稿:網友

當在數據量不是很大,而且沒有后端對應的功能接口的時候,一些簡單的搜索功能基本上是前端去實現的,正好最近用到,寫了一個,貼出來和大家分享:

效果圖:

功能描述:

按下鍵盤后及時搜索條目中的漢字,漢字對應的拼音和號碼;

實現思路:

先將條目中的漢字轉換成拼音,然后將漢字,拼音,數字拼接成規律的字符串,放入數組,然后每次按下鍵盤后判斷 input 中的值是漢字,拼音,還是數字,然后按固定的規律去循環數組,這樣就能找到對應的條目了;

啟用方式:

// search-test-inner --->  最外層div
// search-value --->  input 輸入框
// search-value-list --->  搜索結果顯示div
// search-li --->  搜索條目
new SEARCH_ENGINE("search-test-inner","search-value","search-value-list","search-li");
注意:搜索條目加上兩個臨時數據,data-name 和 data-phone ,用來存儲漢字和數字。

說明:拼音的轉換用到了一個叫 jQuery.Hz2Py-min.js 的插件,由于這個插件只能轉換 input 里的值,所以代碼里多了一個步驟,先將值放入一個臨時的 input ,再轉換。

HTML:

復制代碼 代碼如下:

<div class="search-test-inner">
    <div class="search-val-inner">
        <input type="text" class="search-value" placeholder="搜索">
        <ul class="search-value-list"></ul>
    </div>
    <div class="member-list-inner">
        <ul>
            <li class="search-li" data-name="戰士" data-phone="13914157895">
                <span class="phone">13914157895</span>
                <span class="name">戰士</span>
            </li>
            <li class="search-li" data-name="牧師" data-phone="15112357896">
                <span class="phone">15112357896</span>
                <span class="name">牧師</span>
            </li>
            <li class="search-li" data-name="盜賊" data-phone="13732459980">
                <span class="phone">13732459980</span>
                <span class="name">盜賊</span>
            </li>
            <li class="search-li" data-name="德魯伊" data-phone="18015942365">
                <span class="phone">18015942365</span>
                <span class="name">德魯伊</span>
            </li>
            <li class="search-li" data-name="武僧" data-phone="15312485698">
                <span class="phone">15312485698</span>
                <span class="name">武僧</span>
            </li>
            <li class="search-li" data-name="死靈法師" data-phone="13815963258">
                <span class="phone">13815963258</span>
                <span class="name">死靈法師</span>
            </li>
            <li class="search-li" data-name="圣騎士" data-phone="13815934258">
                <span class="phone">13815934258</span>
                <span class="name">圣騎士</span>
            </li>
        </ul>
    </div>
</div>

CSS:

復制代碼 代碼如下:

* { padding: 0; margin: 0; }
ol , ul { list-style: none; }
body { font-size: 12px; color:#333; }
.search-test-inner { margin: 100px auto; padding: 10px; width: 400px; background: #e0e0e0; border-radius: 10px; box-shadow: 1px 2px 6px #444; }
.search-val-inner { margin-bottom: 20px; padding: 10px; background: #fff; }
.member-list-inner .search-li { padding: 10px; }
.search-value-list { margin-top: 10px; }
.search-value-list li { padding: 5px; }
.member-list-inner .search-li .phone,
.search-value-list li .phone { float: right; }
.search-value { width: 100%; height: 30px; line-height: 30px; }
.tips { font-weight: bold; }

JS:

復制代碼 代碼如下:

//---------------------------------------------------【初始化】
function SEARCH_ENGINE(dom,searchInput,searchResultInner,searchList){
    //存儲拼音+漢字+數字的數組
    this.searchMemberArray = [];
    //作用對象
    this.dom = $("." + dom);
    //搜索框
    this.searchInput = "." + searchInput;
    //搜索結果框
    this.searchResultInner = this.dom.find("." + searchResultInner);
    //搜索對象的名單列表
    this.searchList = this.dom.find("." + searchList);
    //轉換成拼音并存入數組
    this.transformPinYin();
    //綁定搜索事件
    this.searchActiveEvent();
}
SEARCH_ENGINE.prototype = {
    //-----------------------------【轉換成拼音,并將拼音、漢字、數字存入數組】
    transformPinYin : function(){
        //臨時存放數據對象
        $("body").append('<input type="text" class="hidden pingying-box">');
        var $pinyin = $("input.pingying-box");
        for(var i=0;i<this.searchList.length;i++){
            //存放名字,轉換成拼音
            $pinyin.val(this.searchList.eq(i).attr("data-name"));
            //漢字轉換成拼音
            var pinyin = $pinyin.toPinyin().toLowerCase().replace(/s/g,"");
            //漢字
            var cnCharacter = this.searchList.eq(i).attr("data-name");
            //數字
            var digital = this.searchList.eq(i).attr("data-phone");
            //存入數組
            this.searchMemberArray.push(pinyin + "&" + cnCharacter + "&" + digital);
        }
        //刪除臨時存放數據對象
        $pinyin.remove();
    },
    //-----------------------------【模糊搜索關鍵字】
    fuzzySearch : function(type,val){
        var s;
        var returnArray = [];
        //拼音
        if(type === "pinyin"){
            s = 0;
        }
        //漢字
        else if(type === "cnCharacter"){
            s = 1;
        }
        //數字
        else if(type === "digital"){
            s = 2;
        }
        for(var i=0;i<this.searchMemberArray.length;i++){
            //包含字符
            if(this.searchMemberArray[i].split("&")[s].indexOf(val) >= 0){
                returnArray.push(this.searchMemberArray[i]);
            }
        }
        return returnArray;
    },
    //-----------------------------【輸出搜索結果】
    postMemberList : function(tempArray){
        var html = '';
        //有搜索結果
        if(tempArray.length > 0){
            html += '<li class="tips">搜索結果(' + tempArray.length + ')</li>';
            for(var i=0;i<tempArray.length;i++){
                var sArray = tempArray[i].split("&");
                html += '<li>';
                html += '<span class="phone">' + sArray[2] + '</span>';
                html += '<span class="name">' + sArray[1] + '</span>';
                html += '</li>';
            }
        }
        //無搜索結果
        else{
            if($(this.searchInput).val() != ""){
                html += '<li class="tips">無搜索結果……</li>';
            }else{
                this.searchResultInner.html("");
            }
        }
        this.searchResultInner.html(html);
    },
    //-----------------------------【綁定搜索事件】
    searchActiveEvent : function(){
        var searchEngine = this;
        $(document).on("keyup",this.searchInput,function(){
            //臨時存放找到的數組
            var tempArray = [];
            var val = $(this).val();
            //判斷拼音的正則
            var pinYinRule = /^[A-Za-z]+$/;
            //判斷漢字的正則
            var cnCharacterRule = new RegExp("^[/u4E00-/u9FFF]+$","g");
            //判斷整數的正則
            var digitalRule = /^[-+]?d+(.d+)?$/;
            //只搜索3種情況
            //拼音
            if(pinYinRule.test(val)){
                tempArray = searchEngine.fuzzySearch("pinyin",val);
            }
            //漢字
            else if(cnCharacterRule.test(val)){
                tempArray = searchEngine.fuzzySearch("cnCharacter",val);
            }
            //數字
            else if(digitalRule.test(val)){
                tempArray = searchEngine.fuzzySearch("digital",val);
            }
            else{
                searchEngine.searchResultInner.html('<li class="tips">無搜索結果……</li>');
            }
            searchEngine.postMemberList(tempArray);
        });
    }
};

效果是不是非常棒呢,小伙伴們美化下就可以用到自己項目中了

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲女人被黑人巨大进入al| 亚洲黄页视频免费观看| 成人国产精品久久久| 久久久久久久久久国产| 国语自产精品视频在线看一大j8| 日韩av影院在线观看| 色老头一区二区三区| 久久99国产精品久久久久久久久| 欧美怡红院视频一区二区三区| 欧美华人在线视频| 成人精品aaaa网站| 美女精品视频一区| 久久久久久久国产精品视频| 日韩69视频在线观看| 国产精品中文久久久久久久| 777777777亚洲妇女| 国产自产女人91一区在线观看| 国产精品99久久久久久www| 国内外成人免费激情在线视频| 亚洲成人三级在线| 国产区精品在线观看| 亚洲伊人成综合成人网| 日本精品中文字幕| 久久成人这里只有精品| 欧美超级免费视 在线| 欧美黑人又粗大| 亚洲性夜色噜噜噜7777| 中文字幕欧美精品日韩中文字幕| 秋霞午夜一区二区| 欧美一区深夜视频| 久久久久久久久综合| 日韩欧美在线字幕| 国产精品扒开腿做爽爽爽的视频| 亚洲第一福利视频| 黄网站色欧美视频| 精品一区二区三区三区| 欧美大片免费看| 日韩成人免费视频| 久久香蕉精品香蕉| 欧美日韩另类在线| 国产97色在线|日韩| 中文字幕自拍vr一区二区三区| 亚洲最大中文字幕| 欧美韩日一区二区| 精品久久香蕉国产线看观看gif| 久久av中文字幕| 国内精品一区二区三区四区| 91wwwcom在线观看| 日韩成人在线播放| 最近的2019中文字幕免费一页| 欧美日韩一区二区免费视频| 亚洲va欧美va国产综合剧情| 亚洲电影中文字幕| 欧洲日韩成人av| 亚洲美女av在线| 色av吧综合网| 久久精品国产亚洲一区二区| 亚洲www在线| 国产成人在线亚洲欧美| 欧美做受高潮电影o| 日韩av大片免费看| 久久免费少妇高潮久久精品99| 91在线视频导航| 欧美成人激情视频免费观看| 欧美老少做受xxxx高潮| 国产精品三级网站| 国语自产精品视频在线看| 国产精品91一区| 欧美黑人极品猛少妇色xxxxx| 国产在线精品播放| 日韩中文字幕精品视频| 久久久久亚洲精品成人网小说| 日韩欧美国产免费播放| 日韩精品视频免费在线观看| 日韩高清免费在线| 欧美三级xxx| 夜夜嗨av一区二区三区免费区| 日本91av在线播放| 精品国产91久久久久久| 91av在线免费观看| 日韩在线视频导航| 久久久久久免费精品| 亚洲第一精品夜夜躁人人躁| 亚洲天堂男人天堂女人天堂| 精品国产自在精品国产浪潮| 热re99久久精品国产66热| 精品免费在线视频| 日韩免费中文字幕| 在线视频中文亚洲| 亚洲国产中文字幕久久网| 国产一区二区三区在线观看网站| 色琪琪综合男人的天堂aⅴ视频| 日韩av网站在线| 欧美性高潮床叫视频| 成人国产精品久久久| www亚洲欧美| 亚洲一区亚洲二区亚洲三区| 精品国产老师黑色丝袜高跟鞋| 日韩中文av在线| 国产精品久久久久久久久久久久久| 中文字幕日韩电影| 国产欧亚日韩视频| 国产精品久久久久久久av大片| xxav国产精品美女主播| 欧美激情奇米色| 亚洲欧美国产精品专区久久| 日韩中文字幕视频在线观看| 亚洲一区二区三区在线免费观看| 欧洲中文字幕国产精品| 九九九久久国产免费| 最近2019年手机中文字幕| 国产精品白嫩初高中害羞小美女| 亚洲欧美自拍一区| 亚洲精品久久久久久久久久久久久| 国产欧美一区二区白浆黑人| 精品一区电影国产| 日韩av免费网站| 91欧美视频网站| 91精品国产色综合久久不卡98| 中文字幕日韩专区| 91免费观看网站| 日韩在线免费观看视频| 成人av.网址在线网站| 国产亚洲欧洲高清| 亚洲精品国产精品久久清纯直播| 在线亚洲午夜片av大片| 亚洲欧美在线第一页| 69视频在线播放| 国产精品久久久久久久久久尿| 国产香蕉97碰碰久久人人| 在线亚洲男人天堂| 国产精品视频永久免费播放| 成人网在线免费观看| 91精品国产综合久久香蕉最新版| 欧美精品18videos性欧| 久久国产天堂福利天堂| 欧美插天视频在线播放| 久久久在线视频| 成人黄色激情网| 国内精品小视频| 亚洲一区二区免费在线| 国产欧美精品一区二区| 91国语精品自产拍在线观看性色| 国产精品久久久久久久久久三级| 日韩国产精品视频| 中文字幕久热精品在线视频| 日韩中文在线观看| 国产成人精品在线观看| 亚洲自拍av在线| 亚洲精品乱码久久久久久金桔影视| 日本韩国欧美精品大片卡二| 国产欧美一区二区三区久久| 国产精品欧美日韩一区二区| 亚洲综合大片69999| 欧美性视频精品| 日韩国产精品一区| 久久久免费观看| 人九九综合九九宗合| 久久久亚洲国产天美传媒修理工| 国产欧美一区二区三区视频| 日本中文字幕成人| 久久免费视频在线观看| 久久天天躁夜夜躁狠狠躁2022| 国产精品视频资源|