У цьому проблема: мені потрібно генерувати html-код із вмісту даного діва. Тоді я маю помістити цей сирий html-код у текстовій області. Коли я використовую функцію $ (textarea) .val (), як це:
$ (textarea) .val ("деякий html на зразок <type type = 'text' value = '' style =" background: url ('http://www.w.com/bg.gif') center-x center; "/> бла-бла");
або
$ ('# idTxtArGenHtml'). val ($ ('idDivMain'). html ());
У мене виникли проблеми з деяким спеціальним символом (& '"), коли вони знаходяться між". Але коли я використовую функцію: $ (textarea) .html (), текст нормально.
Є приклад форми:
<FORM id="idFormContact" name="nFormContact" action="send.php" method="post" >
<FIELDSET id="idFieldContact" class="CMainFieldset">
<LEGEND>Test your newsletter» </LEGEND>
<p>Send to à : <input id='idInpMailList' type='text' value='youremail@gmail.com' /></p>
<FIELDSET class="CChildFieldset">
<LEGEND>Subject</LEGEND>
<LABEL for="idNomClient" class="CInfoLabel">Enter the subject: * </LABEL><BR/>
<INPUT value="" name="nSubject" type="text" id="idSubject" class="CFormInput" alt="Enter the Subject" ><BR/>
</FIELDSET>
<FIELDSET class="CChildFieldset">
<INPUT id="idBtnGen" type="button" value="Generate" onclick="onGenHtml();"/>
<INPUT id="idBtnSend" type="button" value="Send" onclick="onSend();"/><BR/><BR/>
<LEGEND>Message</LEGEND>
<LABEL for="idTxtArGenHtml" class="CInfoLabel">Html code : * </LABEL><BR/>
<span><TEXTAREA name="nTxtArGenHtml" id="idTxtArGenHtml" width='100%' cols="69" rows="300" alt="enter your message" ></TEXTAREA></span>
</FIELDSET>
</FIELDSET>
</FORM>
І код JavaScript / jquery, який не працює для заповнення текстової області, є:
function onGenHtml(){
$('#idTxtArGenHtml').html( $("#idDivMain").html() );
}
Нарешті рішення:
function onGenHtml(){
$('#idTxtArGenHtml').html( $("#idDivMain").html() );
$('#idTxtArGenHtml').parent().replaceWith( '<span>'+$('#idTxtArGenHtml').parent().html()+'</span>');
}
Трюк - обернути текстові області тегом "span", щоб допомогти з функцією substituWith. Я не впевнений, чи він дуже чистий, але він ідеально працює, також додайте код HTML у текстовій області.