日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

django為Form生成的label標簽添加class方式

瀏覽:35日期:2024-10-02 13:57:37

使用Form生成html標簽的時候,雖然提供了widget的方法可以自定義標簽的要是,但是只能給生成的input標簽添加樣式,對于生成的label標簽無法添加樣式。

而很多場景下需要為label和input都添加class以實現(xiàn)自定義樣式。

測試環(huán)境

創(chuàng)建一個Form,通過Form幫我們生成HTML:

# urls.py 文件,對應關系 path(’email/’, views.email), # forms.py 文件from django.forms import Formfrom django.forms import fieldsfrom django.forms import widgets class UserEmail(Form): username = fields.CharField() password = fields.CharField( widget=widgets.PasswordInput(attrs={’class’: ’c1’}) ) email = fields.EmailField( widget=widgets.EmailInput(attrs={’class’: ’c1’}) ) # views.py 文件def email(request): obj = forms.UserEmail() print(obj[’email’].label_tag(attrs={’class’: ’c1’})) # 其實生成標簽的方法是提供attrs參數(shù)的 return render(request, ’demo/email.html’, {’obj’: obj})

在html中,直接使用Form幫我生成的表單:

<body>{{ obj.as_p }}{{ obj.email.label_tag }}{{ obj.email }}</body>

這里可以看到,input標簽里都是有class屬性的,但是lable標簽里沒有,并且Form組件里貌似也沒有提供為label標簽增加自定義屬性的方式。

通過模板語言的自定義函數(shù)實現(xiàn)

上面的views里的 print(obj[’email’].label_tag(attrs={’class’: ’c1’})) ,從輸出看,django提供的生成label標簽的方法是支持attrs參數(shù)實現(xiàn)自定義屬性的,問題是在前端使用模板語言的時候只能這樣 {{ obj.email.label_tag }} 無法傳入?yún)?shù)。這里就自定義個模板語言的函數(shù)來解決這個問題。

自定義函數(shù)

要自定義函數(shù),按照下面的步驟操作:

在APP下,創(chuàng)建templatetags目錄,目錄名字很重要不能錯。

創(chuàng)建任意 .py 文件,這里文件名隨意,比如:myfun.py。

文件里創(chuàng)建一個template.Library()對象,名字是register。這里的對象名字必須是register。

然后寫自己的函數(shù),但是都用@register.simple_tag這個裝飾器裝飾好:

自定義的函數(shù)如下:

# app名/templatetags/myfun.py 文件from django import templateregister = template.Library() @register.filter(is_safe=True)def label_with_classes(value, arg): return value.label_tag(attrs={’class’: arg})

然后在頁面中使用自定義的函數(shù):

<body>{{ obj.as_p }}{{ obj.email.label_tag }}{{ obj.email }}{% load myfun %}{{ obj.email|label_with_classes:’c1 c2’ }}</body>

注意,上面的自定義函數(shù)引用的時候參數(shù)和參數(shù)之間一定不能有空格。

這里還有一個好處,把添加前端樣式的代碼放到了前端的html里實現(xiàn)了。

為input標簽也寫一個自定義函數(shù)

django默認的方法是在Form里,通過widgets小部件添加attrs參數(shù)來實現(xiàn)標簽的自定義樣式。這是在放在后端實現(xiàn)的。上面已經(jīng)實現(xiàn)了前端的自定義樣式,這里找了到生成input標簽的方法,就是as_widget()。

照著樣子再寫一個子定義函數(shù):

# app名/templatetags/myfun.py 文件from django import templateregister = template.Library() @register.filter()def label_with_classes(value, arg): return value.label_tag(attrs={’class’: arg}) @register.filter()def widget_with_classes(value, arg): return value.as_widget(attrs={’class’: arg})

最后,上面搞得難么麻煩,主要是為了可以前端一個for循環(huán),就能把表單按自定義的樣式顯示出來:

<body><link rel='stylesheet' rel='external nofollow' integrity='sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u' crossorigin='anonymous'>{% load myfun %}<form class='form-horizontal'>{% for item in obj %} <div class='form-group'> {{ item|label_with_classes:’col-sm-2 control-label’ }} <div class='col-sm-10'> {{ item|widget_with_classes:’form-control’ }} </div> </div>{% endfor %}</form></body>

補充知識:Django Forms組件 的參數(shù)配置案例 input樣式, 渲染的標簽加class 錯誤信息提示

Forms渲染出標簽類型

密碼型、文本型、郵箱型框

from django.forms import widgets# 自定義格式方法class UserForm(forms.Form): ’’’最小4位 且 模式:普通文本’’’ name = forms.CharField(min_length=4, label=’姓名:’,widget=widgets.TextInput()) ’’’最小4位 且 模式:密碼模式’’’ pwd = forms.CharField(min_length=4, label=’密碼:’, widget=widgets.PasswordInput())

渲染時添加屬性 class=’’(便于bootstrap)

from django.forms import widgets’’’在widgets.類型(加入字典形式的標簽信息)’’’class UserForm(forms.Form): # 模式:普通文本 標簽加上: name = forms.CharField(widget=widgets.TextInput(attrs={’class’: ’form-control’})) # 模式:密碼模式 標簽加上: pwd = forms.CharField(widget=widgets.PasswordInput( attrs={’class’: ’form-control’} ))

渲染自定義錯誤提示

視圖

from django.forms import widgets’’’追加error_messages參數(shù) dict型式’’’class UserForm(forms.Form): # 模式:required=不能為空的提示 name = forms.CharField(min_length=4, label=’姓名:’, error_messages={ ’title’: {’required’: ’不能為空哦親親’}, ’price’: {’invalid’: ’格式錯誤(提示方法)’}, # ’字段’: {’錯誤類型’: ’提示信息’} }) # 模式:invalid=格式錯誤 pwd = forms.CharField(min_length=4, label=’密碼:’, error_messages={ ’title’: {’required’: ’不能為空哦親親’}, ’price’: {’invalid’: ’格式錯誤(提示方法)’}, # ’字段’: {’錯誤類型’: ’提示信息’} })

HTML展示錯誤信息

<form action='' method='post' novalidate='novalidate'> <!--要自定義提示必須 novalidate='novalidate'--> {% csrf_token %} {% for field in form %} <p> {{ field.label }}{{ field }} <span>{{ field.errors.0 }}</span> <!--錯誤信息固定:field.errors.0 --> </p> {% endfor %} <p><input type='submit' value='提交'></p> </form>

以上這篇django為Form生成的label標簽添加class方式就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標簽: Django
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
一区二区三区四区在线观看国产日韩| 日韩激情精品| 免费在线亚洲欧美| 国产aⅴ精品一区二区三区久久| 日本在线啊啊| 国产成人精品一区二区三区免费| 国产精品a级| 久久中文欧美| 国产九九精品| 精品国产一区二区三区2021| 福利片在线一区二区 | 日韩专区精品| 欧美aa在线观看| 国产精品av一区二区| 一区三区视频| 亚洲日本三级| 国产精品综合色区在线观看| 久久久久九九精品影院| 超级白嫩亚洲国产第一| 久久精品免费一区二区三区| 欧美日韩一二三四| 婷婷综合社区| 亚洲一区二区三区无吗| 日韩高清电影免费| 国内在线观看一区二区三区| 日本不良网站在线观看| 亚洲免费黄色| 91精品一区| 久久久久久久欧美精品| 视频一区欧美日韩| 欧美精品国产一区| 欧美激情视频一区二区三区在线播放| 精品一区二区三区中文字幕| 久久免费黄色| 亚洲精品极品| 精品国产精品国产偷麻豆| 91精品一区二区三区综合| 免费视频一区二区| 欧美交a欧美精品喷水| 三上悠亚国产精品一区二区三区| 在线综合亚洲| 国产精品一级| 久久久天天操| 啪啪亚洲精品| 四虎4545www国产精品| 亚洲香蕉久久| 久久中文字幕一区二区三区| 999精品在线| 日韩欧美另类中文字幕| 在线天堂中文资源最新版| 国产农村妇女精品一二区| 国产精品视频首页| 激情综合亚洲| 国产精品亚洲人成在99www| 中文另类视频| 亚洲毛片在线免费| 国产黄大片在线观看| 免费视频久久| 日本精品黄色| 日韩1区2区3区| 亚洲成人精品| 久久精品 人人爱| 国产在线成人| 国产高清日韩| 久久aⅴ国产紧身牛仔裤| 国产一区二区三区国产精品| 热久久国产精品| 正在播放日韩精品| 日韩欧美中文字幕电影| 欧美福利一区| 国产精品视频一区二区三区 | 久久亚洲成人| 日韩激情啪啪| 欧美国产91| 国产一区二区三区日韩精品| 亚洲精品在线国产| 久久精品影视| 欧美黑人巨大videos精品| 巨乳诱惑日韩免费av| 日韩黄色大片网站| 国产欧美自拍| 欧洲激情综合| zzzwww在线看片免费| 日本va欧美va精品发布| 亚洲激情不卡| 91精品久久久久久久久久不卡| 国产精品1区在线| 中文无码日韩欧| 久久亚洲国产| 综合激情网...| 国产不卡av一区二区| 人人爱人人干婷婷丁香亚洲| 日本在线啊啊| 国产激情综合| 欧美日本三区| 免费视频最近日韩| 99精品在线观看| 精品理论电影在线| 国产精品自拍区| 日韩激情啪啪| 色综合视频一区二区三区日韩| 欧美日韩日本国产亚洲在线| 麻豆国产精品一区二区三区| 日韩不卡手机在线v区| 亚洲精品四区| 亚洲人成网77777色在线播放| 亚洲激情久久| 亚洲国产专区校园欧美| 欧美亚洲日本精品| 久久久国产精品网站| 国产精品久久久网站| 日韩精品欧美大片| 免费观看在线色综合| 欧美精品一区二区久久| 亚洲成人va| 日韩黄色大片网站| av综合电影网站| 亚洲精品永久免费视频| 国产亚洲一卡2卡3卡4卡新区| 视频在线观看一区| 亚洲免费影院| 亚洲资源av| 丝袜美腿亚洲色图| 国产亚洲激情| 巨乳诱惑日韩免费av| 亚洲欧洲一区| 美日韩精品视频| 石原莉奈在线亚洲三区| 午夜国产精品视频免费体验区| 99国产精品| 美女91精品| 日本一区二区三区视频在线看 | 日韩在线短视频| 日韩成人综合| 日本韩国欧美超级黄在线观看| 蜜桃av.网站在线观看| 国产精品久久久久av电视剧| 久久精品青草| 国产亚洲精品久久久久婷婷瑜伽| 日韩视频二区| 日韩在线观看中文字幕| 国产亚洲人成a在线v网站| 美腿丝袜亚洲一区| 中国字幕a在线看韩国电影| 国产在线|日韩| jiujiure精品视频播放| 影音先锋国产精品| 中文字幕一区二区三区日韩精品 | 欧美日韩日本国产亚洲在线| 国产亚洲在线| 日韩av一二三| 久久精品色播| 久久久夜夜夜| 日韩中文字幕1| 日本午夜精品一区二区三区电影| 国产精品一国产精品| 黑人精品一区| 亚洲欧美视频一区二区三区| 日韩1区2区日韩1区2区| 美女视频黄久久| 亚洲天堂一区二区| 蜜臀久久久99精品久久久久久| 久久激情av| 欧美精选视频一区二区| 蜜桃视频免费观看一区| 国产精成人品2018| 91精品国产91久久久久久黑人| 免费人成网站在线观看欧美高清| 国产精品观看| 欧美+亚洲+精品+三区| 日韩国产欧美一区二区三区| 国产一区二区三区天码| 国产亚洲激情| 欧美国产视频| 1024精品一区二区三区| 三级一区在线视频先锋| 美腿丝袜在线亚洲一区| 欧美成人综合| 久久成人高清| 一区三区视频| 国产精品日本一区二区不卡视频 | 喷白浆一区二区| 免费日韩成人| 亚洲a一区二区三区| 日韩福利视频导航| 日韩欧美一区二区三区在线观看| 亚洲一区av| 久久久久久一区二区| 免费成人在线观看| 亚洲综合电影| 国产情侣一区| 婷婷综合在线| 欧美黄色一区二区| 亚洲男女自偷自拍| 中国字幕a在线看韩国电影| 亚洲精品麻豆| 久久精品亚洲欧美日韩精品中文字幕| 91精品国产自产在线丝袜啪| 亚洲精品一区三区三区在线观看| 亚洲伊人精品酒店|