Вот как я это делаю:
{{ 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]" />
, а затем подсчитали его длину?