搜索功能在使用特殊字符“(+?)”时发生崩溃,同时灼烧文本..?

时间:2013-07-19 10:39:10

标签: jquery

你能告诉我为什么在搜索页面上的文本时使用这个特殊字符的应用程序崩溃。我正在从页面搜索文本。它工作正常但是在使用像这样的特殊字符“(+?)”时崩溃了它转到上一个屏幕.. 其次\ t。

这是我的小提琴..? http://jsfiddle.net/4BAau/5/

function searchAndHighlight(searchTerm, selector) {
    if (searchTerm) {
        var selector = selector || "#realTimeContents";
        var searchTermRegEx = new RegExp('('+searchTerm+')', "ig");
        var matches = $(selector).text().match(searchTermRegEx);
        if (matches != null && matches.length > 0) {
            $('.highlighted').removeClass('highlighted');

            $span = $('#realTimeContents span');
            $span.replaceWith($span.html());

            var txt = $(selector).text().replace(searchTermRegEx, '<span class="match">$1</span>');

            $(selector).html(txt);

            $('.match:first').addClass('highlighted');

            var i = 0;

            $('.next_h').off('click').on('click', function () {
                i++;

                if (i >= $('.match').length) i = 0;

                $('.match').removeClass('highlighted');
                $('.match').eq(i).addClass('highlighted');
                $('.ui-mobile-viewport').animate({
                    scrollTop: $('.match').eq(i).offset().top
                }, 300);
            });
            $('.previous_h').off('click').on('click', function () {

                i--;

                if (i < 0) i = $('.match').length - 1;

                $('.match').removeClass('highlighted');
                $('.match').eq(i).addClass('highlighted');
                $('.ui-mobile-viewport').animate({
                    scrollTop: $('.match').eq(i).offset().top
                }, 300);
            });




            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");
    }


});

1 个答案:

答案 0 :(得分:0)

这些字符在正则表达式中具有特殊含义 - 它们需要被转义

更新 - 非常快速(又有点脏)修复:

var searchTermRegEx = new RegExp('('+searchTerm.replace(/([[\]()+{}?])/,'\\$1')+')', "ig");