From 5e42e9f0592f987a9caba3b1322ba070927a1195 Mon Sep 17 00:00:00 2001 From: Tim Graham Date: Tue, 5 Aug 2014 08:40:27 -0400 Subject: [PATCH] [1.7.x] Fixed #21792 -- Documented Form.has_changed() Thanks bjb at credil.org for the suggestion and Ivan Mesic for the draft patch. Backport of edcc75e5ac from master --- docs/ref/forms/api.txt | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/docs/ref/forms/api.txt b/docs/ref/forms/api.txt index 48c6fadca1..2a0e7daf3f 100644 --- a/docs/ref/forms/api.txt +++ b/docs/ref/forms/api.txt @@ -245,6 +245,31 @@ precedence:: Url: Comment: +Checking if form data has changed +--------------------------------- + +.. method:: Form.has_changed() + +Use the ``has_changed()`` method on your ``Form`` when you need to check if the +form data has been changed from the initial data. + + >>> data = {'subject': 'hello', + ... 'message': 'Hi there', + ... 'sender': 'foo@example.com', + ... 'cc_myself': True} + >>> f = ContactForm(initial=data) + >>> f.has_changed() + False + +When the form is submitted, we reconstruct it and provide the original data +so that the comparison can be done: + + >>> f = ContactForm(request.POST, initial=data) + >>> f.has_changed() + +``has_changed()`` will be ``True`` if the data from ``request.POST`` differs +from what was provided in :attr:`~Form.initial` or ``False`` otherwise. + Accessing the fields from the form ----------------------------------