Как получить элемент по innerText - PullRequest
99 голосов
/ 28 сентября 2010

Как получить тег на html странице, если я знаю, что содержит текстовый тег.Например:

<a ...>SearchingText</a>

Ответы [ 12 ]

104 голосов
/ 28 сентября 2010

Вам придется пройти вручную.

var aTags = document.getElementsByTagName("a");
var searchText = "SearchingText";
var found;

for (var i = 0; i < aTags.length; i++) {
  if (aTags[i].textContent == searchText) {
    found = aTags[i];
    break;
  }
}

// Use `found`.
96 голосов
/ 27 марта 2015

Вы можете использовать xpath для выполнения этого

var xpath = "//a[text()='SearchingText']";
var matchingElement = document.evaluate(xpath, document, null, XPathResult.FIRST_ORDERED_NODE_TYPE, null).singleNodeValue;

Вы также можете искать элемент, содержащий некоторый текст, используя этот xpath:

var xpath = "//a[contains(text(),'Searching')]";
29 голосов
/ 28 июня 2015

Вы можете использовать jQuery : содержит () селектор

var element = $( "a:contains('SearchingText')" );
25 голосов
/ 20 марта 2017

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

for (const a of document.querySelectorAll("a")) {
  if (a.textContent.includes("your search term")) {
    console.log(a.textContent)
  }
}

или с отдельным фильтром:

[...document.querySelectorAll("a")]
   .filter(a => a.textContent.includes("your search term"))
   .forEach(a => console.log(a.textContent))

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

13 голосов
/ 27 октября 2014

Хотя прошло довольно много времени, и вы уже (давно) приняли ответ, я подумал, что предложу обновленный подход:

function findByTextContent(needle, haystack, precise) {
  // needle: String, the string to be found within the elements.
  // haystack: String, a selector to be passed to document.querySelectorAll(),
  //           NodeList, Array - to be iterated over within the function:
  // precise: Boolean, true - searches for that precise string, surrounded by
  //                          word-breaks,
  //                   false - searches for the string occurring anywhere
  var elems;

  // no haystack we quit here, to avoid having to search
  // the entire document:
  if (!haystack) {
    return false;
  }
  // if haystack is a string, we pass it to document.querySelectorAll(),
  // and turn the results into an Array:
  else if ('string' == typeof haystack) {
    elems = [].slice.call(document.querySelectorAll(haystack), 0);
  }
  // if haystack has a length property, we convert it to an Array
  // (if it's already an array, this is pointless, but not harmful):
  else if (haystack.length) {
    elems = [].slice.call(haystack, 0);
  }

  // work out whether we're looking at innerText (IE), or textContent 
  // (in most other browsers)
  var textProp = 'textContent' in document ? 'textContent' : 'innerText',
    // creating a regex depending on whether we want a precise match, or not:
    reg = precise === true ? new RegExp('\\b' + needle + '\\b') : new RegExp(needle),
    // iterating over the elems array:
    found = elems.filter(function(el) {
      // returning the elements in which the text is, or includes,
      // the needle to be found:
      return reg.test(el[textProp]);
    });
  return found.length ? found : false;;
}


findByTextContent('link', document.querySelectorAll('li'), false).forEach(function(elem) {
  elem.style.fontSize = '2em';
});

findByTextContent('link3', 'a').forEach(function(elem) {
  elem.style.color = '#f90';
});
<ul>
  <li><a href="#">link1</a>
  </li>
  <li><a href="#">link2</a>
  </li>
  <li><a href="#">link3</a>
  </li>
  <li><a href="#">link4</a>
  </li>
  <li><a href="#">link5</a>
  </li>
</ul>

Конечно, несколько проще:

var textProp = 'textContent' in document ? 'textContent' : 'innerText';

// directly converting the found 'a' elements into an Array,
// then iterating over that array with Array.prototype.forEach():
[].slice.call(document.querySelectorAll('a'), 0).forEach(function(aEl) {
  // if the text of the aEl Node contains the text 'link1':
  if (aEl[textProp].indexOf('link1') > -1) {
    // we update its style:
    aEl.style.fontSize = '2em';
    aEl.style.color = '#f90';
  }
});
<ul>
  <li><a href="#">link1</a>
  </li>
  <li><a href="#">link2</a>
  </li>
  <li><a href="#">link3</a>
  </li>
  <li><a href="#">link4</a>
  </li>
  <li><a href="#">link5</a>
  </li>
</ul>

Ссылки:

12 голосов
/ 13 июля 2017

Функциональный подход.Возвращает массив всех совпадающих элементов и разделяет пробелы вокруг при проверке.

function getElementsByText(str, tag = 'a') {
  return Array.prototype.slice.call(document.getElementsByTagName(tag)).filter(el => el.textContent.trim() === str.trim());
}

Использование

getElementsByText('Text here'); // second parameter is optional tag (default "a")

, если вы просматриваете различные теги, например, span или button

getElementsByText('Text here', 'span');
getElementsByText('Text here', 'button');

Значение тега по умолчанию = 'a' понадобится Babel для старых браузеров

4 голосов
/ 20 апреля 2017

Я обнаружил, что использование более нового синтаксиса немного короче по сравнению с ответом других. Итак, вот мое предложение:

const callback = element => element.innerHTML == 'My research'

const elements = Array.from(document.getElementsByTagName('a'))
// [a, a, a, ...]

const result = elements.filter(callback)

console.log(result)
// [a]

JSfiddle.net

2 голосов
/ 13 марта 2019

Просто передайте подстроку в следующую строку:

Внешний HTML

document.documentElement.outerHTML.includes('substring')

Внутренний HTML

document.documentElement.innerHTML.includes('substring')
1 голос
/ 28 сентября 2010

Хотя по внутреннему тексту можно понять, я думаю, вы идете не в ту сторону. Эта внутренняя строка генерируется динамически? Если это так, вы можете присвоить тегу класс или - еще лучше - ID, когда текст будет добавлен. Если это статично, то это еще проще.

0 голосов
/ 14 декабря 2017

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

Используйте document.getElementsByInnerText(), чтобы получить несколько элементов (несколько элементов могут иметь один и тот же точныйтекст), и используйте document.getElementByInnerText(), чтобы получить только один элемент (первое совпадение).

Кроме того, вы можете локализовать поиск, используя элемент (например, someElement.getElementByInnerText()) вместо document.

Возможно, вам придется настроить его для кросс-браузерности или удовлетворения ваших потребностей.

Я думаю, что код не требует пояснений, поэтому я оставлю его как есть.

HTMLElement.prototype.getElementsByInnerText = function (text, escape) {
    var nodes  = this.querySelectorAll("*");
    var matches = [];
    for (var i = 0; i < nodes.length; i++) {
        if (nodes[i].innerText == text) {
            matches.push(nodes[i]);
        }
    }
    if (escape) {
        return matches;
    }
    var result = [];
    for (var i = 0; i < matches.length; i++) {
        var filter = matches[i].getElementsByInnerText(text, true);
        if (filter.length == 0) {
            result.push(matches[i]);
        }
    }
    return result;
};
document.getElementsByInnerText = HTMLElement.prototype.getElementsByInnerText;

HTMLElement.prototype.getElementByInnerText = function (text) {
    var result = this.getElementsByInnerText(text);
    if (result.length == 0) return null;
    return result[0];
}
document.getElementByInnerText = HTMLElement.prototype.getElementByInnerText;

console.log(document.getElementsByInnerText("Text1"));
console.log(document.getElementsByInnerText("Text2"));
console.log(document.getElementsByInnerText("Text4"));
console.log(document.getElementsByInnerText("Text6"));

console.log(document.getElementByInnerText("Text1"));
console.log(document.getElementByInnerText("Text2"));
console.log(document.getElementByInnerText("Text4"));
console.log(document.getElementByInnerText("Text6"));
<table>
    <tr>
        <td>Text1</td>
    </tr>
    <tr>
        <td>Text2</td>
    </tr>
    <tr>
        <td>
            <a href="#">Text2</a>
        </td>
    </tr>
    <tr>
        <td>
            <a href="#"><span>Text3</span></a>
        </td>
    </tr>
    <tr>
        <td>
            <a href="#">Special <span>Text4</span></a>
        </td>
    </tr>
    <tr>
        <td>
            Text5
            <a href="#">Text6</a>
            Text7
        </td>
    </tr>
</table>
...