Как получить все текстовые узлы в документе HTML от определенных тегов с помощью JavaScript? - PullRequest
2 голосов
/ 06 декабря 2010

Как получить все textNodes из группы определенных тегов, скажем «blockquote, em, h4, h6, p» в одном массиве, без использования xpath или treewalker (IE не позволяет использовать xpath & treewalker) ..пожалуйста, помогите мне ... все нормально, если скрипт только для IE.

Ответы [ 2 ]

2 голосов
/ 06 декабря 2010

Следующее даст вам все текстовые узлы, содержащиеся в соответствующем элементе:

function getTextNodes(root, tagNamesArray) {
    var textNodes = [];
    var regex = new RegExp("^(" + tagNamesArray.join("|") + ")$", "i");
    var insideMatchingElement = false;

    function getNodes(node, insideMatchingElement) {
        if (node.nodeType == 3 && insideMatchingElement) {
            textNodes.push(node);
        } else if (node.nodeType == 1) {
            var childrenInsideMatchingElement = insideMatchingElement || regex.test(node.nodeName);
            for (var child = node.firstChild; child; child = child.nextSibling) {
                getNodes(child, childrenInsideMatchingElement);
            }
        }
    }

    getNodes(root);
    return textNodes;
}

var textNodes = getTextNodes(document.body, ["blockquote","em","h4","h6","p"]);
0 голосов
/ 06 декабря 2010

Использовать JQuery

$('blockquote,em,h4,h6,p').each(function(i, v) { alert(v); })

ОБНОВЛЕНИЕ, чтобы получить текст элемента

$('blockquote,em,h4,h6,p').each(function(i, v) { alert(v.text()); })
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...