jQuery 實現前端模糊匹配與首字母搜索

實現效果

image

源碼

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>搜索框測試Demo</title>
    <style>
        .searchDiv {width: 400px;height: 400px;margin: 150px auto;}
        .on {font-size: 12px;font-weight: 700;color: red;}
        /* 隱藏 拼音 標簽 */
        p {display: none;}
    </style>
    <script type="text/javascript" src="../asset/js/jquery-3.2.1.min.js"></script>
    <script type="text/javascript">
        $(function(){
            //鍵盤按鍵彈起時執行
            $('#index').keyup(function(){
                var index = $.trim($('#index').val().toString()); // 去掉兩頭空格
                if(index == ''){ // 如果搜索框輸入為空
                    $('li').removeClass('on');
                    return false;
                }
                var parent = $('ul');
                $('li').removeClass('on');
                //選擇包含文本框值的所有加上focus類樣式,并把它(們)移到ul的最前面
                // prependTo() 方法在被選元素的開頭(仍位于內部)插入指定內容
                // contains 選擇器,選取包含指定字符串的元素
                $("li:contains('"+index+"')").prependTo(parent).addClass('on');
                $("p:contains('"+index+"')").parent().prependTo(parent).addClass('on');
            });
        });
    </script>
</head>
<body>
    <div class="searchDiv">
        我要搜:<input type="text" id="index"/>
        <ul>
            <li>鄭州的文武<p>zzdww</p></li>
            <li>我來自新鄉市<p>wlzxxs</p></li>
            <li>我的母校是中原工學院<p>wdmxszygxy</p></li>
            <li>我叫鄭斌<p>wjzb</p></li>
            <li>芳齡22<p>fl22</p></li>
        </ul>
    </div>
</body>
</html>

注意:
用到了 jQuery 提供的 :contains 選擇器,詳情參考:http://www.w3school.com.cn/jquery/selector_contains.asp

本文轉載地址:https://www.cnblogs.com/zhengbin/p/6790657.html?utm_source=itdadao&utm_medium=referral

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。