Когда я использую метод jQuery append()
, результирующий вывод HTML происходит не в том порядке, который я намереваюсь.
Как вы видите в тестовом примере ниже, каждый раз, когда я открываю тег DIV
, не закрывая его, он все равно закрывается.
То же самое относится и к тегу <ul>
- который также был закрыт раньше, чем я ожидал - я хотел, чтобы он закрывался после второго тега <li>
, который должен быть вложен под ним.
Какой лучший способ построить большой блок динамического HTML в том порядке, в котором он написан?
$('#a').remove(); // remove #a from the dom and re-insert it dynamically
$("<div id='a'>").insertAfter('div#main');
$('#a').append(" <ul>");
$('#a').append(" <li>A</li>");
$('#a').append(" <li>B</li>");
$('#a').append(" </ul>");
$('#a').append(" <div id='X1'>");
$('#a').append(" <div id='b'>");
$('#a').append(" <div id='b1'></div>");
$('#a').append(" <div id='b2'></div>");
$('#a').append(" </div>");
$('#a').append(" <div id='c'>");
$('#a').append(" <p id='c1'></p>");
$('#a').append(" </div>");
$('#a').append(" </div>");
$('#a').append(" <div id='X2'>B</div>");
$('#a').append("</div>");
<div id="main>
<div id="a>
<ul></ul> // <ul> tag is closed!?
<li>A</li>
<li>B</li>
<div id='X1'></div> // div is closed!?
<div id='b'> // div is closed!?
<div id='b1'></div>
<div id='b2'></div>
<div id='c'></div> // div is closed!?
<p id='c1'></p>
<div id='X2'>B</div>
</div>
</div>