Я создаю форму, в которой пользователю необходимо динамически добавлять элементы формы. addEmptyItem () выполняет это путем клонирования первого элемента в данном списке, очистки его значений, обновления его индексов и добавления его.
Конечно, требуется, чтобы в списке был хотя бы один элемент списка. Мое решение состоит в том, чтобы всегда отображать первый элемент списка, а затем перебирать остальные. Это беспокоит меня из-за дублирования кода. Хуже, когда элементы списка содержат много полей.
То, что я хочу, - это что-то похожее на цикл do-while. Любые предложения, как решить эту проблему без дублирования кода, как я делаю сейчас:
<s:submit type="button" onclick="addEmptyItem($('#owners')); return false;"
value="%{getText('ownership.addOwner')}"/>
<ul id="owners">
<li>
<s:textfield name="ownership.owner[0].name"
label="%{getText('ownership.owner.name')}"/>
<s:textfield name="ownership.owner[0].share"
label="%{getText('ownership.owner.share')}"/>
</li>
<s:iterator value="ownership.owner" status="i" begin="1">
<li>
<s:textfield name="ownership.owner[%{#i.count}].name"
label="%{getText('ownership.owner.name')}"/>
<s:textfield name="ownership.owner[%{#i.count}].share"
label="%{getText('ownership.owner.share')}"/>
</li>
</s:iterator>
</ul>