校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > html頁面中完成查找功能

html頁面中完成查找功能

熱門標(biāo)簽:默納克系統(tǒng)外呼顯示inns 昌邑外呼系統(tǒng) 東莞人工外呼系統(tǒng)多少錢 400電話是在哪里申請 地圖標(biāo)注地點下載 朝陽自動外呼系統(tǒng) 400電話辦理尚景 商丘電話自動外呼系統(tǒng)怎么收費 周口導(dǎo)航地圖標(biāo)注

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

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

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

html是這樣:

 <div class="container" style="z-index: 999" id="searchDiv">
        <div class="keyword-search">
            查找:
            <input id="key" type="text" style="width: 200px;" placeholder="關(guān)鍵詞" />
            <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)原理:

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

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

focusMove方法就是使頁面定位到當(dāng)前元素的操作。

學(xué)到的jquery方法:

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

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

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

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

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

總結(jié)

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

標(biāo)簽:湖南 健身房 沈陽 福建 阿拉善盟 那曲 揭陽 銅陵

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《html頁面中完成查找功能》,本文關(guān)鍵詞  html,頁面,中,完成,查找,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《html頁面中完成查找功能》相關(guān)的同類信息!
  • 本頁收集關(guān)于html頁面中完成查找功能的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    成人午夜免费av| 久久久精品综合| 一区二区三区精品在线观看| 国产精品一线二线三线精华| 日韩一区二区在线看| 天天操天天色综合| 欧美日韩高清在线播放| 夜夜操天天操亚洲| 色噜噜夜夜夜综合网| 亚洲精品免费播放| 91国产成人在线| 亚洲.国产.中文慕字在线| 国产成人精品午夜视频免费| 精品国产91乱码一区二区三区 | 日韩精品一区二区三区中文不卡| 日韩电影在线一区二区三区| 欧美一区二区三区的| 懂色av中文字幕一区二区三区| 国产福利一区二区三区视频在线 | 亚洲bt欧美bt精品777| 99久久精品国产一区二区三区| 国产精品久久久久久久久免费桃花 | 亚洲国产视频直播| 欧美精品精品一区| 精品一区二区在线免费观看| 国产视频视频一区| av在线不卡观看免费观看| 夜夜亚洲天天久久| 欧美三级日韩三级| 亚洲国产aⅴ成人精品无吗| 欧美日韩日本视频| 一区二区理论电影在线观看| 欧美日韩精品福利| 精品伊人久久久久7777人| 久久嫩草精品久久久精品一| 波波电影院一区二区三区| 亚洲免费视频成人| 日韩写真欧美这视频| 久久精工是国产品牌吗| 2024国产精品| 99视频精品全部免费在线| 午夜日韩在线电影| 久久久精品日韩欧美| 蜜臂av日日欢夜夜爽一区| 欧美精品一区二区不卡| 色欧美片视频在线观看在线视频| 日本成人超碰在线观看| 精品国产a毛片| 国产成人av电影在线观看| 亚洲精品高清在线| 久久女同互慰一区二区三区| 欧美伊人久久久久久久久影院 | 久久久精品黄色| 色综合网站在线| 日产欧产美韩系列久久99| 久久久久国产免费免费| 99这里都是精品| 久久99深爱久久99精品| 亚洲欧美色综合| 精品国产污污免费网站入口| 91热门视频在线观看| 韩日av一区二区| 香蕉久久夜色精品国产使用方法| 久久九九影视网| 51午夜精品国产| 国产成a人亚洲精品| 亚洲国产日韩精品| 欧美日韩国产123区| 97精品久久久午夜一区二区三区 | 日韩三级伦理片妻子的秘密按摩| 国产精品18久久久久久久网站| 亚洲国产视频a| 亚洲精品视频一区二区| 国产精品视频一二三区| 精品日韩成人av| 91麻豆精品国产| 欧美吻胸吃奶大尺度电影 | 国产精品国产三级国产aⅴ无密码| 欧美一级搡bbbb搡bbbb| 欧美日韩成人一区| 在线观看一区日韩| 色婷婷激情久久| 国产精品一区二区三区99| 天涯成人国产亚洲精品一区av| 亚洲免费电影在线| 亚洲美女淫视频| 亚洲欧美一区二区三区孕妇| 国产精品国产自产拍在线| 国产嫩草影院久久久久| 精品国产三级a在线观看| 欧美电影在哪看比较好| 欧美另类变人与禽xxxxx| 成人综合日日夜夜| 成人免费毛片高清视频| 国产精品亚洲成人| 国产在线精品一区二区夜色| 国产尤物一区二区在线| 男女男精品网站| 久久精品免费观看| 国产在线精品不卡| 成人免费福利片| 色综合久久久久综合体| 色婷婷久久一区二区三区麻豆| 在线观看视频一区二区欧美日韩| 99久久婷婷国产综合精品电影| 国产激情一区二区三区四区 | 国产iv一区二区三区| 福利一区二区在线| 99久久99精品久久久久久| 欧美视频自拍偷拍| 欧美性xxxxxxxx| 欧美日韩成人高清| 欧美日韩精品欧美日韩精品一| 色婷婷综合五月| 欧美日韩电影在线| 久久综合国产精品| 中文字幕亚洲成人| 亚洲成av人影院在线观看网| 免费观看30秒视频久久| 岛国av在线一区| 欧美在线免费播放| 日韩限制级电影在线观看| 日韩视频免费直播| 成人免费在线视频| 日韩精品免费专区| 久久成人18免费观看| 国产一区二区网址| 91久久精品一区二区三| 欧美一级片免费看| 中文字幕免费观看一区| 亚洲一二三四久久| 国产一区二区三区观看| 一本久道久久综合中文字幕| 欧美喷潮久久久xxxxx| 91精品在线免费| 日本一区二区三区在线观看| 亚洲一区在线观看免费 | 欧美亚洲精品一区| 精品国精品自拍自在线| 亚洲资源中文字幕| 欧美色倩网站大全免费| 欧美一级日韩一级| 一区二区三区四区亚洲| 国产精品一区二区你懂的| 欧洲一区二区三区在线| 国产女人aaa级久久久级| 亚洲国产综合人成综合网站| 精品在线免费观看| 欧美性欧美巨大黑白大战| 国产日韩在线不卡| 久久精品国产99国产精品| 色婷婷av一区二区三区之一色屋| www久久久久| 日本美女一区二区| 在线观看中文字幕不卡| 国产精品乱人伦| 国产乱码精品一区二区三| 一本色道综合亚洲| 国产欧美一区二区精品仙草咪| 日韩成人午夜精品| 日本韩国视频一区二区| 国产精品成人免费在线| 国产高清在线观看免费不卡| 欧美一区二区在线免费播放| 亚洲美女免费在线| 国产风韵犹存在线视精品| 日韩欧美一区二区视频| 亚洲一级二级在线| 在线欧美日韩国产| 亚洲精品日日夜夜| 91免费在线播放| 亚洲三级在线看| 91丨porny丨户外露出| 欧美xxxx老人做受| 亚洲日本电影在线| 91成人网在线| 一区二区三区蜜桃网| 日本久久精品电影| 亚洲美女屁股眼交3| 91一区二区三区在线观看| 国产精品亲子伦对白| 成人午夜伦理影院| 国产精品美女久久久久久 | 亚洲人精品午夜| av不卡在线播放| 自拍偷拍亚洲综合| 色爱区综合激月婷婷| 亚洲综合偷拍欧美一区色| 日本道在线观看一区二区| 国产精品第一页第二页第三页| 色偷偷一区二区三区| 亚洲午夜在线视频| 91精品国产全国免费观看| 日韩成人伦理电影在线观看| 日韩一级片在线观看| 国产精品99久久久久久似苏梦涵| 日本一区二区三区四区在线视频| 成人在线视频一区| 国产精品色婷婷| 在线不卡免费av|