Вот как я это делаю:
{{ formset.management_form }}
<table>
{% for form in formset.forms %}
{{ form }}
{% endfor %}
</table>
<a href="javascript:void(0)" id="add_form">Add Form</a>
А вот и JS:
var form_count = {{formset.total_form_count}};
$('#add_form').click(function() {
form_count++;
var form = '{{formset.empty_form|escapejs}}'.replace(/__prefix__/g, form_count);
$('#forms').append(form)
$('#id_form-TOTAL_FORMS').val(form_count);
});
Что меня особенно беспокоит, так это то, что мне пришлось самому написать этот тег шаблона escapejs
. Он просто удаляет все новые строки и экранирует любые одинарные кавычки, чтобы не испортить мою строку. Но что именно ожидали от нас создатели Django в этой ситуации? И почему у них есть это TOTAL_FORMS
скрытое поле, когда они могли просто использовать массив типа <input name="my_form_field[0]" />
, а затем подсчитать его длину?