mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +00:00 
			
		
		
		
	Fixed #23307 -- Clarified the way max_num limits the output of formsets.
Thanks velle for the report.
This commit is contained in:
		| @@ -91,8 +91,7 @@ Limiting the maximum number of forms | |||||||
| ------------------------------------ | ------------------------------------ | ||||||
|  |  | ||||||
| The ``max_num`` parameter to :func:`~django.forms.formsets.formset_factory` | The ``max_num`` parameter to :func:`~django.forms.formsets.formset_factory` | ||||||
| gives you the ability to limit the maximum number of empty forms the formset | gives you the ability to limit the number of forms the formset will display:: | ||||||
| will display:: |  | ||||||
|  |  | ||||||
|     >>> from django.forms.formsets import formset_factory |     >>> from django.forms.formsets import formset_factory | ||||||
|     >>> from myapp.forms import ArticleForm |     >>> from myapp.forms import ArticleForm | ||||||
| @@ -103,16 +102,22 @@ will display:: | |||||||
|     <tr><th><label for="id_form-0-title">Title:</label></th><td><input type="text" name="form-0-title" id="id_form-0-title" /></td></tr> |     <tr><th><label for="id_form-0-title">Title:</label></th><td><input type="text" name="form-0-title" id="id_form-0-title" /></td></tr> | ||||||
|     <tr><th><label for="id_form-0-pub_date">Pub date:</label></th><td><input type="text" name="form-0-pub_date" id="id_form-0-pub_date" /></td></tr> |     <tr><th><label for="id_form-0-pub_date">Pub date:</label></th><td><input type="text" name="form-0-pub_date" id="id_form-0-pub_date" /></td></tr> | ||||||
|  |  | ||||||
| If the value of ``max_num`` is greater than the number of existing | If the value of ``max_num`` is greater than the number of existing items in the | ||||||
| objects, up to ``extra`` additional blank forms will be added to the formset, | initial data, up to ``extra`` additional blank forms will be added to the | ||||||
| so long as the total number of forms does not exceed ``max_num``. | formset, so long as the total number of forms does not exceed ``max_num``. For | ||||||
|  | example, if ``extra=2`` and ``max_num=2`` and the formset is initalized with | ||||||
|  | one ``initial`` item, a form for the initial item and one blank form will be | ||||||
|  | displayed. | ||||||
|  |  | ||||||
|  | If the number of items in the initial data exceeds ``max_num``, all initial | ||||||
|  | data forms will be displayed regardless of the value of ``max_num`` and no | ||||||
|  | extra forms will be displayed. For example, if ``extra=3`` and ``max_num=1`` | ||||||
|  | and the formset is initialized with two initial items, two forms with the | ||||||
|  | initial data will be displayed. | ||||||
|  |  | ||||||
| A ``max_num`` value of ``None`` (the default) puts a high limit on the number | A ``max_num`` value of ``None`` (the default) puts a high limit on the number | ||||||
| of forms displayed (1000). In practice this is equivalent to no limit. | of forms displayed (1000). In practice this is equivalent to no limit. | ||||||
|  |  | ||||||
| If the number of forms in the initial data exceeds ``max_num``, all initial |  | ||||||
| data forms will be displayed regardless.  (No extra forms will be displayed.) |  | ||||||
|  |  | ||||||
| By default, ``max_num`` only affects how many forms are displayed and does not | By default, ``max_num`` only affects how many forms are displayed and does not | ||||||
| affect validation.  If ``validate_max=True`` is passed to the | affect validation.  If ``validate_max=True`` is passed to the | ||||||
| :func:`~django.forms.formsets.formset_factory`, then ``max_num`` will affect | :func:`~django.forms.formsets.formset_factory`, then ``max_num`` will affect | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user