jQuery « JQuery работа с кодом из переменной

что если значала делаем так
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .javascript.geshi_code {font-family:monospace;} .javascript.geshi_code .imp {font-weight: bold; color: red;} .javascript.geshi_code .kw1 {color: #000066; font-weight: bold;} .javascript.geshi_code .kw2 {color: #003366; font-weight: bold;} .javascript.geshi_code .kw3 {color: #000066;} .javascript.geshi_code .co1 {color: #006600; font-style: italic;} .javascript.geshi_code .co2 {color: #009966; font-style: italic;} .javascript.geshi_code .coMULTI {color: #006600; font-style: italic;} .javascript.geshi_code .es0 {color: #000099; font-weight: bold;} .javascript.geshi_code .br0 {color: #009900;} .javascript.geshi_code .sy0 {color: #339933;} .javascript.geshi_code .st0 {color: #3366CC;} .javascript.geshi_code .nu0 {color: #CC0000;} .javascript.geshi_code .me1 {color: #660066;} .javascript.geshi_code span.xtra { display:block; }

$varka = $('div').html().replace('p', 'div');
 


т.е. в $varka теперь храниться весь DIV и то что он там заменил.
а как продолжить манипулировать с кодом внутри $varka не вставляя его в DOM и не делая снова выборку, чтоб применять методы дальше.
ну например сделать как бы так
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .javascript.geshi_code {font-family:monospace;} .javascript.geshi_code .imp {font-weight: bold; color: red;} .javascript.geshi_code .kw1 {color: #000066; font-weight: bold;} .javascript.geshi_code .kw2 {color: #003366; font-weight: bold;} .javascript.geshi_code .kw3 {color: #000066;} .javascript.geshi_code .co1 {color: #006600; font-style: italic;} .javascript.geshi_code .co2 {color: #009966; font-style: italic;} .javascript.geshi_code .coMULTI {color: #006600; font-style: italic;} .javascript.geshi_code .es0 {color: #000099; font-weight: bold;} .javascript.geshi_code .br0 {color: #009900;} .javascript.geshi_code .sy0 {color: #339933;} .javascript.geshi_code .st0 {color: #3366CC;} .javascript.geshi_code .nu0 {color: #CC0000;} .javascript.geshi_code .me1 {color: #660066;} .javascript.geshi_code span.xtra { display:block; }

$varka.addClass("blackZone"); // нужен рабочий вариант этой строки
 


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

1 ответов


Во-первых, в переменной не сохраняется объект, а значит к этому значению нельзя приментить addClass() и другие подобные методы. А во-вторых, использование replace('p', 'div') - работает не корректно ( посмотреть результат ). В jQuery используйте .replaceWith() или .replaceAll()
Решение: сохранить в переменную объект $varka = $('div'); , а дальше использовать его по своему усмотрению:


$varka = $('div');
$varka.html();
$varka.addClass("blackZone");
// и т.д.
 
P.S. Если уж очень хотите использовать replace(), то можно чуток доработать код, но на мой взгляд это не очень красиво:

$varka = $('div');
$varka.html().replace('p','div').replace('/p','/div');
$varka.addClass("blackZone");
 
Получается, что-то в этом роде