mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #9336. Changed CheckboxInput to render 'True' and 'False' input strings as checked or not instead of as a value attribute. Thanks, bthomas.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@12556 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -382,7 +382,12 @@ class CheckboxInput(Widget): | |||||||
|             # A missing value means False because HTML form submission does not |             # A missing value means False because HTML form submission does not | ||||||
|             # send results for unselected checkboxes. |             # send results for unselected checkboxes. | ||||||
|             return False |             return False | ||||||
|         return super(CheckboxInput, self).value_from_datadict(data, files, name) |         value = data.get(name) | ||||||
|  |         # Translate true and false strings to boolean values. | ||||||
|  |         values =  {'true': True, 'false': False} | ||||||
|  |         if isinstance(value, basestring): | ||||||
|  |             value = values.get(value.lower(), value) | ||||||
|  |         return value | ||||||
|  |  | ||||||
|     def _has_changed(self, initial, data): |     def _has_changed(self, initial, data): | ||||||
|         # Sometimes data or initial could be None or u'' which should be the |         # Sometimes data or initial could be None or u'' which should be the | ||||||
|   | |||||||
| @@ -295,6 +295,24 @@ attribute in the Form gets precedence. | |||||||
| >>> print f['get_spam'] | >>> print f['get_spam'] | ||||||
| <input checked="checked" type="checkbox" name="get_spam" /> | <input checked="checked" type="checkbox" name="get_spam" /> | ||||||
|  |  | ||||||
|  | 'True' or 'true' should be rendered without a value attribute | ||||||
|  | >>> f = SignupForm({'email': 'test@example.com', 'get_spam': 'True'}, auto_id=False) | ||||||
|  | >>> print f['get_spam'] | ||||||
|  | <input checked="checked" type="checkbox" name="get_spam" /> | ||||||
|  |  | ||||||
|  | >>> f = SignupForm({'email': 'test@example.com', 'get_spam': 'true'}, auto_id=False) | ||||||
|  | >>> print f['get_spam'] | ||||||
|  | <input checked="checked" type="checkbox" name="get_spam" /> | ||||||
|  |  | ||||||
|  | A value of 'False' or 'false' should be rendered unchecked | ||||||
|  | >>> f = SignupForm({'email': 'test@example.com', 'get_spam': 'False'}, auto_id=False) | ||||||
|  | >>> print f['get_spam'] | ||||||
|  | <input type="checkbox" name="get_spam" /> | ||||||
|  |  | ||||||
|  | >>> f = SignupForm({'email': 'test@example.com', 'get_spam': 'false'}, auto_id=False) | ||||||
|  | >>> print f['get_spam'] | ||||||
|  | <input type="checkbox" name="get_spam" /> | ||||||
|  |  | ||||||
| Any Field can have a Widget class passed to its constructor: | Any Field can have a Widget class passed to its constructor: | ||||||
| >>> class ContactForm(Form): | >>> class ContactForm(Form): | ||||||
| ...     subject = CharField() | ...     subject = CharField() | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user