mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	newforms: The Form classes created by form_for_model() now have a create() method, which creates a model instance from the clean_data
git-svn-id: http://code.djangoproject.com/svn/django/trunk@4216 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -7,6 +7,15 @@ from forms import BaseForm, DeclarativeFieldsMetaclass, SortedDictFromList | |||||||
|  |  | ||||||
| __all__ = ('form_for_model', 'form_for_fields') | __all__ = ('form_for_model', 'form_for_fields') | ||||||
|  |  | ||||||
|  | def create(self, save=True): | ||||||
|  |     "Creates and returns model instance according to self.clean_data." | ||||||
|  |     if self.errors: | ||||||
|  |         raise ValueError("The %s could not be created because the data didn't validate." % self._model._meta.object_name) | ||||||
|  |     obj = self._model(**self.clean_data) | ||||||
|  |     if save: | ||||||
|  |         obj.save() | ||||||
|  |     return obj | ||||||
|  |  | ||||||
| def form_for_model(model): | def form_for_model(model): | ||||||
|     "Returns a Form class for the given Django model class." |     "Returns a Form class for the given Django model class." | ||||||
|     opts = model._meta |     opts = model._meta | ||||||
| @@ -16,7 +25,7 @@ def form_for_model(model): | |||||||
|         if formfield: |         if formfield: | ||||||
|             field_list.append((f.name, formfield)) |             field_list.append((f.name, formfield)) | ||||||
|     fields = SortedDictFromList(field_list) |     fields = SortedDictFromList(field_list) | ||||||
|     return type(opts.object_name + 'Form', (BaseForm,), {'fields': fields, '_model_opts': opts}) |     return type(opts.object_name + 'Form', (BaseForm,), {'fields': fields, '_model': model, 'create': create}) | ||||||
|  |  | ||||||
| def form_for_fields(field_list): | def form_for_fields(field_list): | ||||||
|     "Returns a Form class for the given list of Django database field instances." |     "Returns a Form class for the given list of Django database field instances." | ||||||
|   | |||||||
| @@ -2,6 +2,13 @@ | |||||||
| 34. Generating HTML forms from models | 34. Generating HTML forms from models | ||||||
|  |  | ||||||
| Django provides shortcuts for creating Form objects from a model class. | Django provides shortcuts for creating Form objects from a model class. | ||||||
|  |  | ||||||
|  | The function django.newforms.form_for_model() takes a model class and returns | ||||||
|  | a Form that is tied to the model. This Form works just like any other Form, | ||||||
|  | with one additional method: create(). The create() method creates an instance | ||||||
|  | of the model and returns that newly created instance. It saves the instance to | ||||||
|  | the database if create(save=True), which is default. If you pass | ||||||
|  | create(save=False), then you'll get the object without saving it. | ||||||
| """ | """ | ||||||
|  |  | ||||||
| from django.db import models | from django.db import models | ||||||
| @@ -23,6 +30,10 @@ class Article(models.Model): | |||||||
|  |  | ||||||
| __test__ = {'API_TESTS': """ | __test__ = {'API_TESTS': """ | ||||||
| >>> from django.newforms import form_for_model | >>> from django.newforms import form_for_model | ||||||
|  |  | ||||||
|  | >>> Category.objects.all() | ||||||
|  | [] | ||||||
|  |  | ||||||
| >>> CategoryForm = form_for_model(Category) | >>> CategoryForm = form_for_model(Category) | ||||||
| >>> f = CategoryForm() | >>> f = CategoryForm() | ||||||
| >>> print f | >>> print f | ||||||
| @@ -44,4 +55,50 @@ __test__ = {'API_TESTS': """ | |||||||
| {} | {} | ||||||
| >>> f.clean_data | >>> f.clean_data | ||||||
| {'url': u'entertainment', 'name': u'Entertainment'} | {'url': u'entertainment', 'name': u'Entertainment'} | ||||||
|  | >>> obj = f.create() | ||||||
|  | >>> obj | ||||||
|  | <Category: Entertainment> | ||||||
|  | >>> Category.objects.all() | ||||||
|  | [<Category: Entertainment>] | ||||||
|  |  | ||||||
|  | >>> f = CategoryForm({'name': "It's a test", 'url': 'test'}) | ||||||
|  | >>> f.errors | ||||||
|  | {} | ||||||
|  | >>> f.clean_data | ||||||
|  | {'url': u'test', 'name': u"It's a test"} | ||||||
|  | >>> obj = f.create() | ||||||
|  | >>> obj | ||||||
|  | <Category: It's a test> | ||||||
|  | >>> Category.objects.all() | ||||||
|  | [<Category: Entertainment>, <Category: It's a test>] | ||||||
|  |  | ||||||
|  | >>> f = CategoryForm({'name': 'Third test', 'url': 'third'}) | ||||||
|  | >>> f.errors | ||||||
|  | {} | ||||||
|  | >>> f.clean_data | ||||||
|  | {'url': u'third', 'name': u'Third test'} | ||||||
|  | >>> obj = f.create(save=False) | ||||||
|  | >>> obj | ||||||
|  | <Category: Third test> | ||||||
|  | >>> Category.objects.all() | ||||||
|  | [<Category: Entertainment>, <Category: It's a test>] | ||||||
|  | >>> obj.save() | ||||||
|  | >>> Category.objects.all() | ||||||
|  | [<Category: Entertainment>, <Category: It's a test>, <Category: Third test>] | ||||||
|  |  | ||||||
|  | >>> f = CategoryForm({'name': '', 'url': 'foo'}) | ||||||
|  | >>> f.errors | ||||||
|  | {'name': [u'This field is required.']} | ||||||
|  | >>> f.clean_data | ||||||
|  | >>> f.create() | ||||||
|  | Traceback (most recent call last): | ||||||
|  | ... | ||||||
|  | ValueError: The Category could not be created because the data didn't validate. | ||||||
|  |  | ||||||
|  | >>> f = CategoryForm({'name': '', 'url': 'foo'}) | ||||||
|  | >>> f.create() | ||||||
|  | Traceback (most recent call last): | ||||||
|  | ... | ||||||
|  | ValueError: The Category could not be created because the data didn't validate. | ||||||
|  |  | ||||||
| """} | """} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user