欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

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

html頁面中完成查找功能

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

最近在搞一個被很多人改了的框架,天天看代碼看的頭的暈了,不過感覺進步還挺大的,自己做了一個后臺可配置前臺查看兩個庫不同數據范圍的東西,還挺滿意,那天拿出來分享一下,今天先說一個這幾天做的功能,就是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頁面中完成查找功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

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

巨人網絡通訊聲明:本文標題《html頁面中完成查找功能》,本文關鍵詞  html,頁面,中,完成,查找,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《html頁面中完成查找功能》相關的同類信息!
  • 本頁收集關于html頁面中完成查找功能的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    亚洲乱码一区二区三区在线观看| 丁香网亚洲国际| 亚洲熟女一区二区三区| 一本大道久久a久久综合婷婷| 国产视频911| 国模套图日韩精品一区二区| chinese麻豆新拍video| 欧美伦理电影网| 午夜日韩在线电影| 国产乱淫av片| 在线播放一区二区三区| 亚洲成人动漫在线免费观看| 波多野结衣三级视频| 欧美视频一区二区三区在线观看| 亚洲黄色片在线观看| 97se亚洲国产综合自在线不卡| 色拍拍在线精品视频8848| 一区免费观看视频| 91蜜桃免费观看视频| 欧美在线一二三| 亚洲一区二区三区中文字幕| 性一交一黄一片| 欧美精品久久一区二区三区| 亚洲成人在线免费| aaaaa一级片| 26uuu国产日韩综合| 九一九一国产精品| 91传媒免费观看| 最新高清无码专区| 国产免费无码一区二区| 制服丝袜激情欧洲亚洲| 日本va欧美va瓶| 日韩福利在线视频| 中文字幕五月欧美| 又大又长粗又爽又黄少妇视频| 宅男在线国产精品| 久久国产精品区| 中文字幕在线观看2018| 亚洲欧美日韩中文播放 | 午夜精品久久久久久久蜜桃app| jjzzjjzz欧美69巨大| 欧美一级高清片在线观看| 另类成人小视频在线| www.99re6| 亚洲主播在线播放| 蜜桃精品一区二区| 国产精品久久久久久久久久久免费看 | 三级网站在线免费观看| 国产午夜精品久久久久久久 | 国产十八熟妇av成人一区| 日韩你懂的在线播放| 国产一二精品视频| 欧美亚洲高清一区二区三区不卡| 手机精品视频在线观看| 欧美另类69xxxx| 亚洲一区二三区| 极品蜜桃臀肥臀-x88av| 亚洲日穴在线视频| 亚洲一区二区三区无码久久| 欧美激情一区二区三区全黄| 手机看片国产精品| 久久人人超碰精品| 超碰人人cao| 久久亚洲一区二区三区明星换脸| av亚洲精华国产精华精华| 91麻豆精品国产91久久久久久久久| 精品一区精品二区高清| 一本到三区不卡视频| 轻轻草成人在线| 色婷婷av一区二区三区之一色屋| 日本午夜精品视频在线观看| 日本一二三区在线观看| 日韩黄色免费电影| 色悠久久久久综合欧美99| 秋霞电影一区二区| 在线欧美日韩精品| 国产乱子伦视频一区二区三区| 欧美性色综合网| 久久精品国产99国产| 欧美伊人久久久久久午夜久久久久| 久久www免费人成看片高清| 色欧美日韩亚洲| 国产精一品亚洲二区在线视频| 911精品产国品一二三产区 | 欧美xxxx在线观看| 国产男女无遮挡猛进猛出| 久久久国产精品麻豆| 色哟哟无码精品一区二区三区| 国产精品素人一区二区| 手机av免费看| 亚洲一区二区三区小说| 亚洲女人久久久| 麻豆一区二区三| 911国产精品| 成人免费不卡视频| 久久精品人人做人人综合| 国产精品麻豆入口| 一区二区三区日本| 波多野结衣家庭教师| 精品亚洲免费视频| 欧美一级理论片| 亚洲色偷偷色噜噜狠狠99网| 日韩久久一区二区| 国产性生活大片| 国产剧情在线观看一区二区| 日韩欧美国产午夜精品| 成人欧美精品一区二区| 亚洲人成小说网站色在线 | 五月天精品在线| 蜜臀va亚洲va欧美va天堂| 欧美日韩国产综合一区二区 | 成人午夜视频网站| 国产亲近乱来精品视频| 91成人破解版| 青青青伊人色综合久久| 在线成人免费观看| www国产视频| 亚洲成人在线网站| 欧美放荡的少妇| 亚洲成年人在线观看| 亚洲综合激情小说| 欧美日韩中文国产| 91精品国产高清91久久久久久 | 日韩成人av影视| 7777精品伊人久久久大香线蕉完整版 | 亚洲国产毛片aaaaa无费看| 日本韩国欧美一区二区三区| 成人免费电影视频| 亚洲婷婷综合色高清在线| 99久久婷婷国产综合| 国产成人在线视频免费播放| 国产丝袜美腿一区二区三区| 精品丰满少妇一区二区三区| 韩国成人福利片在线播放| 久久综合色鬼综合色| 国产免费无遮挡吸奶头视频| 美国欧美日韩国产在线播放| 精品久久久久久无| wwwww黄色| 豆国产96在线|亚洲| |精品福利一区二区三区| 日本电影欧美片| 91精产国品一二三| 日韩精品电影在线| 337p日本欧洲亚洲大胆精品| 欧美成人国产精品一区二区| 国内久久精品视频| 国产精品丝袜在线| 在线免费观看一区| 老司机免费视频| 久久aⅴ国产欧美74aaa| 国产欧美日韩不卡免费| 国产精品成人免费观看| 欧美体内she精高潮| 午夜视频一区在线观看| 精品国产免费视频| 国精产品一区一区二区三区mba| 99re成人精品视频| 视频一区二区中文字幕| 久久久久综合网| 91精品福利视频| 国产又粗又长又爽| 国产精品一区二区果冻传媒| 亚洲桃色在线一区| 777午夜精品免费视频| 三区四区在线观看| 91一区二区三区在线观看| 婷婷国产v国产偷v亚洲高清| www欧美成人18+| 91高清视频免费看| 性久久久久久久久久| 国产91露脸合集magnet| 亚洲一卡二卡三卡四卡五卡| 精品欧美一区二区久久| 欧美人禽zoz0强交| 亚洲天堂成人av| 夫妻av一区二区| 婷婷综合另类小说色区| 国产网站一区二区| 欧美日韩精品一区二区| 男人舔女人下部高潮全视频| 99久久伊人网影院| 蜜臀av一区二区| 亚洲欧美日韩久久精品| 日韩精品在线看片z| 午夜写真片福利电影网| 成人精品在线观看视频| 成人国产在线观看| 亚洲不卡在线观看| 国产精品久久久久影视| 91精品久久久久久久99蜜桃| 尤物在线免费视频| 自拍视频一区二区| 成人国产一区二区三区精品| 美女性感视频久久| 亚洲最大的成人av| 国产精品女同互慰在线看| 91精品国产91久久久久久最新毛片| 成年人午夜剧场| 夫妇交换中文字幕|