Найти текстовую строку, используя jQuery? - PullRequest
236 голосов
/ 29 мая 2009

Скажем, на веб-странице есть строка типа «Я простая строка», которую я хочу найти. Как бы я пошел по этому поводу с помощью JQuery?

Ответы [ 7 ]

320 голосов
/ 29 мая 2009

jQuery имеет метод содержит. Вот фрагмент кода для вас:

<script type="text/javascript">
$(function() {
    var foundin = $('*:contains("I am a simple string")');
});
</script>

Селектор выше выбирает любой элемент, который содержит целевую строку. Foundin будет объектом jQuery, который содержит любой соответствующий элемент. См. Информацию об API по адресу: http://docs.jquery.com/Selectors/contains#text

С подстановочным знаком '* следует отметить, что вы получите все элементы, включая элементы html a body, которые вам, вероятно, не нужны. Вот почему в большинстве примеров в jQuery и других местах используется $ ('div: Содержит ("Я простая строка")')

50 голосов
/ 29 мая 2009

Обычно селекторы jQuery не выполняют поиск в «текстовых узлах» в DOM. Однако если вы используете функцию .contents (), текстовые узлы будут включены, тогда вы можете использовать свойство nodeType для фильтрации только текстовых узлов и свойство nodeValue для поиска текстовой строки.

    $('*', 'body')
        .andSelf()
        .contents()
        .filter(function(){
            return this.nodeType === 3;
        })
        .filter(function(){
            // Only match when contains 'simple string' anywhere in the text
            return this.nodeValue.indexOf('simple string') != -1;
        })
        .each(function(){
            // Do something with this.nodeValue
        });
28 голосов
/ 29 мая 2009

Это выберет только элементы листа, которые содержат «Я простая строка».

$('*:contains("I am a simple string")').each(function(){
     if($(this).children().length < 1) 
          $(this).css("border","solid 2px red") });

Вставьте следующее в адресную строку, чтобы проверить его.

javascript: $('*:contains("I am a simple string")').each(function(){ if($(this).children().length < 1) $(this).css("border","solid 2px red") }); return false;

Если вы хотите просто взять «Я простая строка» . Сначала оберните текст в такой элемент.

$('*:contains("I am a simple string")').each(function(){
     if($(this).children().length < 1) 
          $(this).html( 
               $(this).text().replace(
                    /"I am a simple string"/
                    ,'<span containsStringImLookingFor="true">"I am a simple string"</span>' 
               )  
           ) 
});

и затем сделайте это.

$('*[containsStringImLookingFor]').css("border","solid 2px red");
17 голосов
/ 29 мая 2009

Если вы просто хотите, чтобы узел находился ближе всего к искомому тексту, вы можете использовать это:

$('*:contains("my text"):last');

Это будет работать, даже если ваш HTML выглядит так:

<p> blah blah <strong>my <em>text</em></strong></p>

Использование вышеупомянутого селектора найдет тег <strong>, так как это последний тег, содержащий всю эту строку.

12 голосов
/ 29 мая 2009

Взгляните на выделение (плагин jQuery).

7 голосов
/ 10 декабря 2014

Просто добавлю к ответу Тони Миллера, так как это дало мне 90% к тому, что я искал, но все еще не работало. Добавление .length > 0; в конец его кода заставило мой скрипт работать.

 $(function() {
    var foundin = $('*:contains("I am a simple string")').length > 0;
 });
2 голосов
/ 13 июня 2013

эта функция должна работать. в основном выполняет рекурсивный поиск, пока мы не получим четкий список листовых узлов.

function distinctNodes(search, element) {
    var d, e, ef;
    e = [];
    ef = [];

    if (element) {
        d = $(":contains(\""+ search + "\"):not(script)", element);
    }
    else {
            d = $(":contains(\""+ search + "\"):not(script)");
    }

    if (d.length == 1) {
            e.push(d[0]);
    }
    else {
        d.each(function () {
            var i, r = distinctNodes(search, this);
            if (r.length === 0) {
                e.push(this);
            }
            else {
                for (i = 0; i < r.length; ++i) {
                    e.push(r[i]);
                }
            }
        });
    }
    $.each(e, function () {
        for (var i = 0; i < ef.length; ++i) {
            if (this === ef[i]) return;
        }
        ef.push(this);
    });
    return ef;
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...