mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +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_dict = SortedDict(field_list) | ||||
|     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 | ||||
|  | ||||
| class ModelFormOptions(object): | ||||
|   | ||||
| @@ -1450,6 +1450,19 @@ ValidationError: [u'Select a valid choice. z is not one of the available choices | ||||
| >>> core.parent | ||||
| <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 | ||||
| >>> import shutil | ||||
| >>> shutil.rmtree(temp_storage_dir) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user