六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網(wǎng)中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

html頁面用js中完成搜索技巧

[摘要]今天先說一個這幾天做的功能,就是html頁面的查找功能。 這個功能主要是實現(xiàn)在html查找框內(nèi)輸入字符,之后按后面的上一個下一個按鈕,會自動把查詢區(qū)域內(nèi)的匹配字符用特殊的樣式標記,之后可以繼續(xù)按上一個下一個按鈕把按照順序瀏覽匹配字符,并把當前匹配的字符用另一種樣式與其他匹配字符加以區(qū)別。付有htm...
今天先說一個這幾天做的功能,就是html頁面的查找功能。 這個功能主要是實現(xiàn)在html查找框內(nèi)輸入字符,之后按后面的上一個下一個按鈕,會自動把查詢區(qū)域內(nèi)的匹配字符用特殊的樣式標記,之后可以繼續(xù)按上一個下一個按鈕把按照順序瀏覽匹配字符,并把當前匹配的字符用另一種樣式與其他匹配字符加以區(qū)別。付有html代碼哦!

樣式演示:

@WG(NDK33XF7CN7R~]85ZI5.png

代碼演示:

html

<div class="container" style="z-index: 999" id="searchDiv">
<div class="keyword-search">
查找:
<input id="key" type="text" style="width: 200px;" placeholder="關鍵詞" />
<a href="javascript:void(0);" class="prev" onclick='wordSearch(1)'><i class="c-icon"></i></a>
<a href="javascript:void(0);" class="next" onclick='wordSearch()'><i class="c-icon"></i></a>
</div>
</div>

script

    <script>//搜索功能
        var oldKey0 = "";
        var index0 = -1;var oldCount0 = 0;
        var newflag = 0;
        var currentLength = 0;

        function wordSearch(flg) {
            var key = $("#key").val(); //取key值
            if (!key) {
                return; //key為空則退出
            }
            getArray();
            focusNext(flg);

        }

        function focusNext(flg) {
            if (newflag == 0) {//如果新搜索,index清零
                index0 = 0;
            }
            if (!flg) {
                if (oldCount0 != 0) {//如果還有搜索
                    if (index0 < oldCount0) {//左邊如果沒走完,走左邊
                        focusMove(index0);
                        index0++;
                    } else if (index0 == oldCount0) {//都走完了
                        index0 = 0;
                        focusMove(index0);
                        index0++;
                    }
                    else {
                        index0 = 0;//沒確定
                        focusMove(index0);
                        index0++;
                    }
                }

            } else {
                if (oldCount0 != 0) {//如果還有搜索
                    if (index0 <= oldCount0 && index0 > 0) {//左邊如果沒走完,走左邊
                        index0--;
                        focusMove(index0);
                    } else if (index0 == 0) {//都走完了
                        index0 = oldCount0;
                        index0--
                        focusMove(index0);
                    }
                }
            }
        }
        function getArray() {
            newflag = 1;
            $(".contrast .result").removeClass("res");
            var key = $("#key").val(); //取key值
            if (!key) {
                oldKey0 = "";
                return; //key為空則退出
            }
            if (oldKey0 != key    $(".current").length != currentLength) {
                //重置
                index0 = 0;
                var index = 0;
                $(".contrast .result").each(function () {
                    $(this).replaceWith($(this).html());
                });
                pos0 = new Array();
                if ($(".contrast-wrap").hasClass("current")) {
                    currentLength = $(".current").length;
                    $(".current .contrast").each(function () {
                        $(this).html($(this).html().replace(new RegExp(key, "gm"), "<span id='result" + (index++) + "' class='result'>" + key + "</span>")); // 替換
                    });
                } else {
                    $(".contrast-wrap").addClass('current');
                    currentLength = $(".current").length;
                    $(".contrast").each(function () {
                        $(this).html($(this).html().replace(new RegExp(key, "gm"), "<span id='result" + (index++) + "' class='result'>" + key + "</span>")); // 替換
                    });
                }
                //$("#key").val(key);
                oldKey0 = key;

                //$(".contrast .result").each(function () {
                //    $(this).parents('.contrast-wrap').addClass('current');
                //    pos0.push($(this).offset().top);
                //});
                // pos0.push($(".contrast .result:eq(2)").offset().top - $(".contrast .result:eq(2)").parents(".contrast").offset().top);
                oldCount0 = $(".contrast .result").length;
                newflag = 0;
            }
        }
        function focusMove(index0) {
            $(".contrast .result:eq(" + index0 + ")").parents('.contrast-wrap').addClass('current');
            $(".contrast .result:eq(" + index0 + ")").addClass("res");
            var top = $(".contrast .result:eq(" + index0 + ")").offset().top + $(".contrast .result:eq(" + index0 + ")").parents(".contrast").scrollTop();
            var intop = top - $(".contrast .result:eq(" + index0 + ")").parents(".contrast").offset().top;
            $(".contrast .result:eq(" + index0 + ")").parents(".contrast").animate({ scrollTop: intop }, 200);
            if ($(".contrast .result:eq(" + index0 + ")").parents(".contrast").scrollTop() == 0) {
                $("html, body").animate({ scrollTop: top - 200 }, 200);
            } else {
                $("html, body").animate({ scrollTop: $(".contrast .result:eq(" + index0 + ")").parents(".contrast").offset().top - 200 }, 200);
            }

        }


        $('#key').change(function () {
            if ($('#key').val() == "") {
                index0 = 0;
                $(".contrast .result").each(function () {
                    $(this).replaceWith($(this).html());
                });
                oldKey0 = "";
            }
        });
    </script>

接下來記一下實現(xiàn)原理:

首先先把上一次的查詢結果清除掉,然后根據(jù)key的值,用正則表達式把區(qū)域內(nèi)所有匹配的字符全都加上特殊的樣式,比如方法中就全部加了一個類名為result的span標簽,用odKey0變量記錄key的值(下次再進入先比較如果一樣的話說明是要看下一個或者上一個的內(nèi)容,就不用在進入用正則表達式匹配了),oldCount0記錄總共查詢出來的個數(shù),newflag置0(如果不是初次查詢newflag為1)。

接著進入getNext方法,flg表示用戶按下的是上一個還是下一個按鈕,用index0記錄當前查看的是哪一個匹配字符,與oldCount0比較,確定是遞增或遞減還是置0(如果大于oldCount0或者小于0,就要重新開始)。

focusMove方法就是使頁面定位到當前元素的操作。

相關推薦:

HTML怎么實現(xiàn)數(shù)字焦點圖輪播代碼

html里怎么插入圖片

HTML里DIV相互重疊怎么辦

HTML里怎么使用margin 0 auto

以上就是html頁面用js中實現(xiàn)查找功能的詳細內(nèi)容,更多請關注php中文網(wǎng)其它相關文章!


網(wǎng)站建設是一個廣義的術語,涵蓋了許多不同的技能和學科中所使用的生產(chǎn)和維護的網(wǎng)站。




主站蜘蛛池模板: 天天五月天丁香婷婷深爱综合 | 四虎影院国产精品 | 自拍亚洲欧美 | 在线视频欧美亚洲 | 亚州人成网在线播放 | 青青草香蕉 | 日本高清色www | 日韩免费不卡 | 偷自拍视频区综合视频区 | 外国成人网在线观看免费视频 | 天天摸夜夜添久久精品麻豆 | 伊人网综合在线观看 | 亚洲成在人线影视天堂网 | 色99色| 日日操日日 | 在线视频 二区 | 五月天婷婷网站 | 字幕网资源站中文字幕 | 中文字幕欧美在线观看 | 亚洲综合色在线观看 | 五月婷婷啪啪 | 午夜激情网站 | 日本在线视 | 午夜国产视频 | 日本天堂在线观看 | 午夜精品久久久久久毛片 | 亚洲欧美日韩高清一区二区三区 | 日韩欧美中文字幕一区 | 香蕉漫画基地成人 | 亚洲成a人v欧美综合天 | 欧洲亚洲欧美国产日本高清 | 日韩精品123 | 色综合久久88色综合天天 | 亚洲六月丁香六月婷婷蜜芽 | 天天干天天射天天插 | 日本特黄特色免费大片 | 日韩城人视频 | 五月激情小说网 | 青娱乐极品视频在线观看 | 特级欧美老少乱配 | 偷拍第1页 |