gpt4 book ai didi

javascript - 使用查询从 div(page) 搜索文本将第二次崩溃

转载 作者:行者123 更新时间:2023-11-29 19:51:30 25 4
gpt4 key购买 nike

我在突出显示搜索词后实现搜索功能。实际上,我还实现了下一个和上一个功能。实际上,当我运行它时,它会正确搜索单词并且用户可以(精细地)进行下一个和上一个。但是当用户第二次搜索时,它也会突出显示第一个词。我在这里实现这个功能。 http://jsfiddle.net/ravi1989/wjLmx/2/

如果检查错误:

首先搜索:sd 然后去next。再次搜索 df。您会发现它还突出显示了第一个单词。

function searchAndHighlight(searchTerm, selector) {
if (searchTerm) {
//var wholeWordOnly = new RegExp("\\g"+searchTerm+"\\g","ig"); //matches whole word only
//var anyCharacter = new RegExp("\\g["+searchTerm+"]\\g","ig"); //matches any word with any of search chars characters
var selector = selector || "#realTimeContents"; //use body as selector if none provided
var searchTermRegEx = new RegExp(searchTerm, "ig");
var matches = $(selector).text().match(searchTermRegEx);
if (matches != null && matches.length > 0) {
$('.highlighted').removeClass('highlighted'); //Remove old search highlights
$(selector).html($(selector).html().replace(searchTermRegEx, "<span class='match'>" + searchTerm + "</span>"));
$('.match:first').addClass('highlighted');
$('.next_h').on('click', i = 1, function () {

$('.match').removeClass('highlighted');
$('.match').eq(i).addClass('highlighted');

i = i + 1;
k = i - 2;

});
$('.previous_h').on('click', k = 1, function () {

if (matches.length > k && k > 0) {
$('.match').removeClass('highlighted');
$('.match').eq(k).addClass('highlighted');
k = k - 1;
i = k + 2;

}
});

if ($('.highlighted:first').length) { //if match found, scroll to where the first one appears
$(window).scrollTop($('.highlighted:first').position().top);
}
return true;
}
}
return false;
}

$(document).on('click', '.searchButtonClickText_h', function (event) {

$(".highlighted").removeClass("highlighted").removeClass("match");
if (!searchAndHighlight($('.textSearchvalue_h').val())) {
alert("No results found");
}
});

最佳答案

您需要删除以前的匹配项: DEMO

        //Remove the previous matches
$span = $('#realTimeContents span');
$span.replaceWith($span.html());

更新 http://jsfiddle.net/wjLmx/16/

关于javascript - 使用查询从 div(page) 搜索文本将第二次崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17638457/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com