Há o problema: eu preciso gerar código html a partir do conteúdo de uma determinada div. Então, eu tenho que colocar esse código html bruto em uma área de texto. Quando eu uso a função $ (textarea) .val () assim:
$ (textarea) .val ("alguns html como <input type = 'text' value = '' style =" background: url ('http://www.w.com/bg.gif') repeat-x center; "/> bla bla");
ou
$ ('# idTxtArGenHtml');
Eu tive problema com algum caractere especial (& '") quando eles estão entre asp. Mas quando eu uso a função: $ (textarea) .html () o texto está ok.
Há um exemplo de formulário:
<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>
E o código javascript / jquery que não funciona para preencher a área de texto é:
function onGenHtml(){
$('#idTxtArGenHtml').html( $("#idDivMain").html() );
}
Finalmente a solução:
function onGenHtml(){
$('#idTxtArGenHtml').html( $("#idDivMain").html() );
$('#idTxtArGenHtml').parent().replaceWith( '<span>'+$('#idTxtArGenHtml').parent().html()+'</span>');
}
O truque é envolver sua área de texto com uma tag span para ajudar na função replaceWith. Não tenho certeza se é muito limpo, mas é um trabalho perfeito também adicionar código html bruto em uma área de texto.