Удалите все элементы, но оставьте выделенными со структурой, используя Cheerio / jQuery - PullRequest
0 голосов
/ 27 сентября 2019

Я хочу указать, какие элементы я хочу сохранить, но с его структурой.Пример:

<html>
    <head>
        <meta xx>
    </head>
    <body>
        <div class="some1">
            <div class="some1-1"></div>
            <div class="some1-2"></div>
            <div class="some1-3"></div>
            <div class="some1-4"></div>
            <div class="some1-5"></div>
        </div>
        <div class="some2">
            <div class="some2-2">
                <div class="some2-2-1"></div>
                <div class="some2-2-2"></div>
            </div>
            <div class="some2-3"></div>
            <div class="some2-4"></div>
            <div class="some2-5"></div>
        </div>
    </body>
</html>

И мне нужно сохранить только для примера: .some2-2-1, .some-2-3, .some-1-3, удалив вседругие элементы, и с сохранением его родителей, так что это будет:

<html>
    <head>
        <meta xx>
    </head>
    <body>
        <div class="some1">
            <div class="some1-3"></div>
        </div>
        <div class="some2">
            <div class="some2-2">
                <div class="some2-2-1"></div>
            </div>
            <div class="some2-3"></div>
        </div>
    </body>
</html>

Я не могу указать, какие элементы я хочу удалить (это динамический), но только какой элемент я хочу сохранить, как выполнитьэто?

$('*:not('.some2-2-1, .some-2-3, .some-1-3')').remove() не будет работать в этом случае;)

1 Ответ

0 голосов
/ 27 сентября 2019

Я уверен, что будет несколько способов сделать это, но вот один из способов (см. Комментарии):

$(function() {
    var elementsToKeep = [
        ".some2-2-1",
        ".some2-3",
        ".some1-3",
    ];

    // parent elements that are needed will be appended here
    var needed = [];

    for (var i = 0; i < elementsToKeep.length; i++) {
        // get the hierarchy, e.g. ".some2-2-1" -> "2-2-1"
        var hierarchyPos = elementsToKeep[i].replace(".some", "");

        // if we're keeping 2-2-1, we also need 2-2, and 2
        //
        // recursively remove the last two characters to get
        // the parent level until there's nothing left
        while (hierarchyPos !== "") {
            if (!needed.includes(hierarchyPos)) {
                needed.push(hierarchyPos);
            }

            hierarchyPos = hierarchyPos.slice(0, -2);
        }
    }

    // "needed" will now contain 2-2-1, 2-2, 2, etc.
    console.log("all required elements:", needed.join(", "));

    // iterate through each of the original selectors
    $(elementsToKeep.join(",")).each(function() {

        // check each of this element's siblings and remove
        // any whose class isn't included in the "needed" array
        var siblings = $(this).siblings();

        siblings.each(function(i, el) {
            var pos = el.className.replace("some", "");

            // if "pos" is 2-2-2 (for example), it won't appear in "needed",
            // so it's safe to remove
            if (!needed.includes(pos)) {
                $(el).remove();
            }
        })
    })

    // finished
    console.log("final output:");
    console.log($("#test").html());
})
<div id="test">
    <div class="some1">
        <div class="some1-1"></div>
        <div class="some1-2"></div>
        <div class="some1-3"></div>
        <div class="some1-4"></div>
        <div class="some1-5"></div>
    </div>
    <div class="some2">
        <div class="some2-2">
            <div class="some2-2-1"></div>
            <div class="some2-2-2"></div>
        </div>
        <div class="some2-3"></div>
        <div class="some2-4"></div>
        <div class="some2-5"></div>
    </div>
</div>

<script src="https://code.jquery.com/jquery-3.4.1.min.js"></script>
...