Surround существующий узел с другим узлом с Agility Pack

c# html-agility-pack

Вопрос

Как бы вы обошли все таблицы с помощью узла <div class="overflow"></div> ? Это, по-видимому, не делает этого:

if (oldElement.Name == "table")
{
    HtmlDocument doc = new HtmlDocument();
    HtmlNode newElement = doc.CreateElement("div");
    newElement.SetAttributeValue("class", "overflow");
    newElement.AppendChild(oldElement);
    oldElement.ParentNode.ReplaceChild(newElement, oldElement);
}

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

if (oldElement.Name == "table")
{
    oldElement.Remove();
}

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

Принятый ответ

Это может быть немного уродливо, но вы можете просто отредактировать атрибут InnerHtml узла oldElement.ParentNode следующим образом:

if (oldElement.Name == "table")
{
    oldElement.ParentNode.InnerHtml = "\r\n<div class=\"overflow\">\r\n"
        + oldElement.OuterHtml +
        "\r\n</div>\r\n";
}

Также не кажется, что вы можете редактировать атрибут OuterHtml oldElement (поэтому вы должны сначала получить ParentNode). HtmlAgilityPack говорит, что вы можете получить / установить OuterHtml, но VS2010 говорил мне, что это свойство только для чтения.

редактировать

Я играл с некоторым кодом, чтобы понять это, и увидел, что oldElement.ParentNode становится узлом <div> после AppendChild() . Решение, которое я нашел, - сделать еще один HtmlNode в начале блока if, чтобы удержать родителя, а затем вызвать ReplaceChild() на этом узле в конце:

if (oldElement.Name == "table")
{
    HtmlNode theParent = oldElement.ParentNode;

    HtmlDocument doc = new HtmlDocument();
    HtmlNode newElement = doc.CreateElement("div");
    newElement.SetAttributeValue("class", "overflow");
    newElement.AppendChild(oldElement);

    theParent.ReplaceChild(newElement, oldElement);
}

Популярные ответы

Взгляните на CsQuery , порт C # для jQuery. Это легко осуществить. Сначала загрузите документ:

CQ doc = CQ.CreateFromFile(..)  // or
CQ doc = CQ.CreateFromUrl(..)   // or
CQ doc = CQ.Create(string)

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

var wrap = CQ.CreateFragment("<div class='overflow'></div>");   // or

// you can pass HTML as a selector as in jQuery. The property indexer for a CQ
// object is the default method, same as $(..)

var wrap = doc["<div class='overflow'></div>"];   // or

var wrap = doc["<div />"].AddClass("overflow");  // or

// creates an element directly, sames as browser DOM methods

var wrap = doc.Document.CreateElement("div");
wrap.ClassName="overflow";

Оберните все таблицы со структурой:

doc["table"].Wrap(wrap);          // or use longhand for the Select method

doc.Select("table").Wrap(wrap);   

Вывести полный текст в строку:

string html = doc.Render();


Related

Лицензировано согласно: CC-BY-SA with attribution
Не связан с Stack Overflow
Лицензировано согласно: CC-BY-SA with attribution
Не связан с Stack Overflow