Dort das Problem: Ich muss HTML-Code aus dem Inhalt eines bestimmten Div generieren. Dann muss ich diesen rohen HTML-Code in einen Textbereich einfügen. Wenn ich die Funktion $ (textarea) .val () wie folgt benutze:
$ (textarea) .val ("einige HTML-Dateien wie <input type = 'text' value = '' style =" background: url ('http://www.w.com/bg.gif') repeat-x center; "/> bla bla");
oder
$ ('# idTxtArGenHtml'). val ($ ('idDivMain'). html ());
Ich hatte ein Problem mit einem Sonderzeichen (& '"), wenn es zwischen Anführungszeichen liegt. Wenn ich jedoch die Funktion $ (textarea) .html () verwende, ist der Text in Ordnung.
Es gibt ein Beispielformular:
<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>
Und Javascript / JQuery-Code, der nicht funktioniert, um den Textbereich zu füllen, ist:
function onGenHtml(){
$('#idTxtArGenHtml').html( $("#idDivMain").html() );
}
Endlich die Lösung:
function onGenHtml(){
$('#idTxtArGenHtml').html( $("#idDivMain").html() );
$('#idTxtArGenHtml').parent().replaceWith( '<span>'+$('#idTxtArGenHtml').parent().html()+'</span>');
}
Der Trick besteht darin, Ihren Textbereich mit einem span-Tag zu versehen, um die Funktion replaceWith zu unterstützen. Ich bin mir nicht sicher, ob es sehr sauber ist, aber es funktioniert auch perfekt. Fügen Sie rohen HTML-Code in einen Textbereich ein.