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

首頁 > 編程 > HTML > 正文

html頁面中完成查找功能

2024-08-26 00:20:06
字體:
來源:轉載
供稿:網友

最近在搞一個被很多人改了的框架,天天看代碼看的頭的暈了,不過感覺進步還挺大的,自己做了一個后臺可配置前臺查看兩個庫不同數據范圍的東西,還挺滿意,那天拿出來分享一下,今天先說一個這幾天做的功能,就是html頁面的查找功能。

這個功能主要是實現在查找框內輸入字符,之后按后面的上一個下一個按鈕,會自動把查詢區域內的匹配字符用特殊的樣式標記,之后可以繼續按上一個下一個按鈕把按照順序瀏覽匹配字符,并把當前匹配的字符用另一種樣式與其他匹配字符加以區別。

前臺顯示大概是這個樣子:

html,查找

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>

接下來記一下實現原理:

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

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

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

學到的jquery方法:

eq() 選擇器:選擇器選取帶有指定 index 值的元素。例如:$(".contrast .result:eq(1)"),就是選擇類名contrast元素中的第二個類名為result的元素。

parents()方法:元素的所有父元素。$("p").parents('.contrast-wrap'),p元素所有類名為contrast-wrap的元素。

replace()方法:用指定的html內容替換被選元素,注意是把被選元素的元素也替換掉。

offset()方法:返回或設置匹配元素相對于文檔的偏移(位置)。

scrollTop()方法:返回或設置匹配元素的滾動條的垂直位置。

總結

以上所述是小編給大家介紹的html頁面中完成查找功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品综合精品自拍| 成人妇女淫片aaaa视频| 亚洲欧美另类中文字幕| 国产亚洲欧美aaaa| 亚洲欧美一区二区激情| 国产精品亚洲综合天堂夜夜| 欧美激情日韩图片| 欧美精品videos另类日本| 日韩欧美999| 中文字幕精品在线视频| 亚洲伊人久久大香线蕉av| 亚洲自拍偷拍在线| 亚洲欧洲偷拍精品| 国产+成+人+亚洲欧洲| 国产精品电影网| 在线观看日韩视频| 久久久伊人日本| 国产精品久久久久77777| 精品色蜜蜜精品视频在线观看| 久久久久久中文字幕| 国产精品99蜜臀久久不卡二区| 精品国产依人香蕉在线精品| 欧洲亚洲免费视频| 日韩在线观看免费网站| 亚洲国产另类久久精品| 欧美成人手机在线| 日韩av免费在线看| 久久99精品国产99久久6尤物| 韩曰欧美视频免费观看| 精品自在线视频| 亚洲精品国产精品自产a区红杏吧| 亚洲国产精品va在线观看黑人| 国产精品无码专区在线观看| 国产高清在线不卡| 日本精品一区二区三区在线播放视频| 亚洲成年人影院在线| 精品国偷自产在线视频| 欧美人与性动交a欧美精品| 成人免费自拍视频| 国产精品免费视频xxxx| 久久精品视频99| 欧美激情一级欧美精品| 精品国产自在精品国产浪潮| 日韩精品在线免费观看视频| 国产精品视频精品| 久久亚洲国产精品成人av秋霞| 成人xxxxx| 亚洲一区二区三区在线免费观看| 国产欧美日韩专区发布| 91国偷自产一区二区三区的观看方式| 中文字幕日韩av综合精品| 亚洲一区二区三| 中文字幕少妇一区二区三区| 97精品视频在线观看| 久久久久久久电影一区| 日韩av日韩在线观看| 在线观看久久av| 亚洲人高潮女人毛茸茸| 深夜精品寂寞黄网站在线观看| 日韩免费电影在线观看| 91av在线免费观看视频| 亚洲片在线资源| 欧美专区在线播放| 亚洲一区999| 中文字幕视频一区二区在线有码| 17婷婷久久www| 亚洲视频在线观看| 成人黄在线观看| 国产精品香蕉av| 日韩av片永久免费网站| 国产精品入口免费视频一| 永久免费毛片在线播放不卡| 日韩经典一区二区三区| 国产精品99久久久久久www| 国产精品青青在线观看爽香蕉| 成人性生交xxxxx网站| 欧美大荫蒂xxx| 国内揄拍国内精品| 亚洲深夜福利在线| 欧美成人网在线| 精品久久久久久久久久久久| 精品国产成人av| 国产精品久久久久久五月尺| 欧美日韩成人在线播放| 国产精品久久久久久久久久久新郎| 亚洲新声在线观看| 欧美日韩美女在线| 国产精品看片资源| 欧美性生交大片免网| 欧美日韩在线观看视频小说| 亚洲精品之草原avav久久| 日韩精品中文字幕在线播放| 日本久久91av| 欧美美女操人视频| 亚洲欧美一区二区激情| 91欧美激情另类亚洲| 欧美一区二区三区精品电影| 亚洲精品成人久久电影| 国产精品久久久久久久久久久久久| 久久久久久久国产| 久久天天躁狠狠躁老女人| 久久久久久久久国产精品| 国产综合色香蕉精品| 欧美性生交大片免费| 日韩av资源在线播放| 欧美激情图片区| 黄色91在线观看| 日韩欧美在线第一页| 茄子视频成人在线| 国产精品18久久久久久麻辣| 美女福利视频一区| 国产精品久久色| 久久精品国产亚洲一区二区| 国产区精品在线观看| 国产精品av网站| 久久精品免费播放| 国产成人精品a视频一区www| 成人免费网站在线观看| 91精品国产综合久久香蕉922| 日韩在线视频网站| 欧美性视频精品| 亚洲福利视频二区| 亚洲午夜精品视频| 欧美亚洲国产视频小说| 亚洲国产另类 国产精品国产免费| 日韩中文字幕在线视频| 国产成人精品一区二区| 亚洲夜晚福利在线观看| 69视频在线免费观看| 国产精品久久久久久久7电影| 亚洲国产成人在线播放| 91sa在线看| 日本精品视频在线| 久久久久久久97| 欧美一级大胆视频| 色妞色视频一区二区三区四区| 久久成人精品一区二区三区| 国产自摸综合网| 国产成人av在线| 亚洲的天堂在线中文字幕| 欧美一二三视频| 久久久久亚洲精品| 8050国产精品久久久久久| 91精品国产九九九久久久亚洲| 性日韩欧美在线视频| 亚洲国产精品专区久久| 久久精品成人动漫| 精品人伦一区二区三区蜜桃网站| 国产精品白丝av嫩草影院| 日韩小视频在线| 久久高清视频免费| 欧美另类极品videosbest最新版本| 日本sm极度另类视频| 91久久久久久国产精品| 欧美视频在线观看免费| 久久99精品久久久久久青青91| 久久久久五月天| 亚洲一区二区三区久久| 精品一区二区三区电影| 欧美俄罗斯乱妇| 亚洲韩国日本中文字幕| 久久久久国产精品免费| 成人激情视频在线播放| 粉嫩老牛aⅴ一区二区三区|