Я использую Greasemonkey и waitForKeyElements()
, чтобы изменить текст на веб-странице.Обертывание текста с помощью span, используя waitForKeyElements, убивает стиль?
Приведен пример одного элемента jNode.
<div class="Ov-h Mx-a">
<div>
<div class="Grid-bind-end">
<div class="ysf-player-name Nowrap Grid-u Relative Lh-xs Ta-start">
<a class="Nowrap" href="http://sports.yahoo.com/nfl/players/7206" target="sports">H. Miller</a> <span class="Fz-xxs">Pit - TE</span>
</div>
</div>
<div class="Grid-bind-end">
<span class="ysf-player-status F-injury Fz-xxs Grid-u Lh-xs"></span>
<div class="ysf-player-detail Nowrap Grid-u Fz-xxs Lh-xs Ta-start">
<span class="ysf-game-status"><a class="F-reset" href="http://sports.yahoo.com/nfl/pittsburgh-steelers-new-england-patriots-20150910017/" onclick="pop(this)" target="sports">Thu 5:30 pm @ NE</a></span>
</div>
</div>
</div>
</div>
Я хочу изменить Thu 5:30 pm @ NE
к Thu 5:30 pm @ < span class="color">NE - [rank]</span>
(Обратите внимание, что [ранг] является переменной у меня есть)
Вот что я пытался
jNode.text((jNode.text().replace("NE","<span class='color'>NE - [rank]</span>")))
Но это заставляет элемент потерять это моделирование.
хорошо, этот вид упаковки - из * текст *, в одном узле - это один из редких иш мест это нормально использовать '.html JQuery в()' в userscript. Существуют «более чистые» методы DOM, но до тех пор, пока замещенный узел не имеет дочерних элементов или обработчиков событий, недостатки минимальны, а '.html()' обычно проще и проще. –