mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #10512 -- Corrected the handling of extra fields on a ModelForm. Thanks to Alex Gaynor for the patch.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@10070 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -163,7 +163,7 @@ def fields_for_model(model, fields=None, exclude=None, formfield_callback=lambda | |||||||
|             field_list.append((f.name, formfield)) |             field_list.append((f.name, formfield)) | ||||||
|     field_dict = SortedDict(field_list) |     field_dict = SortedDict(field_list) | ||||||
|     if fields: |     if fields: | ||||||
|         field_dict = SortedDict([(f, field_dict[f]) for f in fields if (not exclude) or (exclude and f not in exclude)]) |         field_dict = SortedDict([(f, field_dict.get(f)) for f in fields if (not exclude) or (exclude and f not in exclude)]) | ||||||
|     return field_dict |     return field_dict | ||||||
|  |  | ||||||
| class ModelFormOptions(object): | class ModelFormOptions(object): | ||||||
|   | |||||||
| @@ -1450,6 +1450,19 @@ ValidationError: [u'Select a valid choice. z is not one of the available choices | |||||||
| >>> core.parent | >>> core.parent | ||||||
| <Inventory: Pear> | <Inventory: Pear> | ||||||
|  |  | ||||||
|  | >>> class CategoryForm(ModelForm): | ||||||
|  | ...     description = forms.CharField() | ||||||
|  | ...     class Meta: | ||||||
|  | ...         model = Category | ||||||
|  | ...         fields = ['description', 'url'] | ||||||
|  |  | ||||||
|  | >>> CategoryForm.base_fields.keys() | ||||||
|  | ['description', 'url'] | ||||||
|  |  | ||||||
|  | >>> print CategoryForm() | ||||||
|  | <tr><th><label for="id_description">Description:</label></th><td><input type="text" name="description" id="id_description" /></td></tr> | ||||||
|  | <tr><th><label for="id_url">The URL:</label></th><td><input id="id_url" type="text" name="url" maxlength="40" /></td></tr> | ||||||
|  |  | ||||||
| # Clean up | # Clean up | ||||||
| >>> import shutil | >>> import shutil | ||||||
| >>> shutil.rmtree(temp_storage_dir) | >>> shutil.rmtree(temp_storage_dir) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user