這篇文章將為大家詳細講解有關django中怎么利用 forms實現(xiàn)錯誤處理,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
成都創(chuàng)新互聯(lián)公司主要從事網(wǎng)頁設計、PC網(wǎng)站建設(電腦版網(wǎng)站建設)、wap網(wǎng)站建設(手機版網(wǎng)站建設)、成都響應式網(wǎng)站建設公司、程序開發(fā)、網(wǎng)站優(yōu)化、微網(wǎng)站、重慶小程序開發(fā)等,憑借多年來在互聯(lián)網(wǎng)的打拼,我們在互聯(lián)網(wǎng)網(wǎng)站建設行業(yè)積累了豐富的網(wǎng)站制作、成都做網(wǎng)站、網(wǎng)站設計、網(wǎng)絡營銷經(jīng)驗,集策劃、開發(fā)、設計、營銷、管理等多方位專業(yè)化運作于一體。一個form實例.
Form.errors
返回一個ErrorDict實例,包含當前表單所有的錯誤,可以在is_valid之前調(diào)用
Form.has_error(field, code=None)
返回指定field是否有錯誤
Form.add_error(field, error)
向指定field添加一個錯誤
Form.non_field_errors()
不屬于field的錯誤,如數(shù)據(jù)庫中有復合主鍵重復等.
#部分源碼
@property def errors(self): "Returns an ErrorDict for the data provided for the form" if self._errors is None: self.full_clean() return self._errors
@html_safe @python_2_unicode_compatible class ErrorDict(dict): """ A collection of errors that knows how to display itself in various formats. The dictionary keys are the field names, and the values are the errors. """ def as_data(self): return {f: e.as_data() for f, e in self.items()} def as_json(self, escape_html=False): return json.dumps({f: e.get_json_data(escape_html) for f, e in self.items()}) def as_ul(self): if not self: return '' return format_html( '
#官方文檔
Form.
errors
Access the errors
attribute to get a dictionary of error messages:
>>> f.errors{'sender': ['Enter a valid email address.'], 'subject': ['This field is required.']}
In this dictionary, the keys are the field names, and the values are lists of Unicode strings representing the error messages. The error messages are stored in lists because a field can have multiple error messages.
You can access errors
without having to call is_valid()
first. The form’s data will be validated the first time either you callis_valid()
or access errors
.
The validation routines will only get called once, regardless of how many times you access errors
or call is_valid()
. This means that if validation has side effects, those side effects will only be triggered once.
Form.errors.
as_data
()
Returns a dict
that maps fields to their original ValidationError
instances.
>>> f.errors.as_data(){'sender': [ValidationError(['Enter a valid email address.'])],'subject': [ValidationError(['This field is required.'])]}
Use this method anytime you need to identify an error by its code
. This enables things like rewriting the error’s message or writing custom logic in a view when a given error is present. It can also be used to serialize the errors in a custom format (e.g. XML); for instance,as_json()
relies on as_data()
.
The need for the as_data()
method is due to backwards compatibility. Previously ValidationError
instances were lost as soon as their rendered error messages were added to the Form.errors
dictionary. Ideally Form.errors
would have stored ValidationError
instances and methods with an as_
prefix could render them, but it had to be done the other way around in order not to break code that expects rendered error messages in Form.errors
.
Form.errors.
as_json
(escape_html=False)
Returns the errors serialized as JSON.
>>> f.errors.as_json(){"sender": [{"message": "Enter a valid email address.", "code": "invalid"}],"subject": [{"message": "This field is required.", "code": "required"}]}
By default, as_json()
does not escape its output. If you are using it for something like AJAX requests to a form view where the client interprets the response and inserts errors into the page, you’ll want to be sure to escape the results on the client-side to avoid the possibility of a cross-site scripting attack. It’s trivial to do so using a JavaScript library like jQuery - simply use $(el).text(errorText)
rather than.html()
.
If for some reason you don’t want to use client-side escaping, you can also set escape_html=True
and error messages will be escaped so you can use them directly in HTML.
Form.
add_error
(field, error)
This method allows adding errors to specific fields from within the Form.clean()
method, or from outside the form altogether; for instance from a view.
The field
argument is the name of the field to which the errors should be added. If its value is None
the error will be treated as a non-field error as returned by Form.non_field_errors()
.
The error
argument can be a simple string, or preferably an instance of ValidationError
. See Raising ValidationError for best practices when defining form errors.
Note that Form.add_error()
automatically removes the relevant field from cleaned_data
.
Form.
has_error
(field, code=None)
This method returns a boolean designating whether a field has an error with a specific error code
. If code
is None
, it will return True
if the field contains any errors at all.
To check for non-field errors use NON_FIELD_ERRORS
as the field
parameter.
Form.
non_field_errors
()
This method returns the list of errors from Form.errors
that aren’t associated with a particular field. This includes ValidationError
s that are raised in Form.clean()
and errors added using Form.add_error(None, "...")
.
關于django中怎么利用 forms實現(xiàn)錯誤處理就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
創(chuàng)新互聯(lián)www.cdcxhl.cn,專業(yè)提供香港、美國云服務器,動態(tài)BGP最優(yōu)骨干路由自動選擇,持續(xù)穩(wěn)定高效的網(wǎng)絡助力業(yè)務部署。公司持有工信部辦法的idc、isp許可證, 機房獨有T級流量清洗系統(tǒng)配攻擊溯源,準確進行流量調(diào)度,確保服務器高可用性。佳節(jié)活動現(xiàn)已開啟,新人活動云服務器買多久送多久。