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

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

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

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

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

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

測試環境

創建一個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參數的 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標簽增加自定義屬性的方式。

通過模板語言的自定義函數實現

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

自定義函數

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

在APP下,創建templatetags目錄,目錄名字很重要不能錯。

創建任意 .py 文件,這里文件名隨意,比如:myfun.py。

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

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

自定義的函數如下:

# 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})

然后在頁面中使用自定義的函數:

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

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

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

為input標簽也寫一個自定義函數

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

照著樣子再寫一個子定義函數:

# 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循環,就能把表單按自定義的樣式顯示出來:

<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組件 的參數配置案例 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參數 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方式就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
极品裸体白嫩激情啪啪国产精品| 欧美日本不卡高清| 久久精品一区二区国产| 久久精品国产99久久| 日本欧美韩国一区三区| 久久久久网站| 免费在线亚洲| 极品日韩av| 国产精品久久国产愉拍| 国产尤物精品| 国产精品亚洲片在线播放| 成人午夜在线| 精品一区二区三区的国产在线观看| 日韩精品欧美成人高清一区二区| 久久免费高清| 91一区二区| 国产一区二区三区四区二区| 国产欧美精品久久| 国产精品一卡| 性欧美xxxx免费岛国不卡电影| 久久不卡日韩美女| 啪啪国产精品| 亚洲精品乱码| 久久不见久久见国语| 91一区二区三区四区| av在线资源| 91精品精品| 日韩一区二区在线免费| 色婷婷精品视频| 老司机精品视频网| 精品国产欧美日韩| 日韩av有码| 亚洲综合电影| 久久一区欧美| 美美哒免费高清在线观看视频一区二区| 日韩视频一区| 亚洲专区在线| 日韩精品一区二区三区免费视频| 亚洲精品激情| 久久国产乱子精品免费女| 婷婷综合福利| 91亚洲精品在看在线观看高清| 亚洲欧美成人综合| 日本а中文在线天堂| 欧美日韩国产在线一区| 亚洲麻豆一区| 日韩av资源网| 波多野结衣久久精品| 精品视频网站| 激情婷婷欧美| 婷婷亚洲精品| 国产九九精品| 桃色一区二区| 亚洲高清成人| 亚洲国产一区二区三区在线播放| 欧美日韩在线播放视频| 国产精品美女久久久| 五月亚洲婷婷 | 精品视频一区二区三区在线观看 | 丝瓜av网站精品一区二区| 日韩国产欧美一区二区三区| 国产h片在线观看| 日韩1区2区3区| 国产成人精品一区二区免费看京| 香蕉久久夜色精品国产| 亚洲精品少妇| 亚洲综合二区| 欧美日韩一区二区三区四区在线观看 | 国产一区二区三区日韩精品| 电影91久久久| 97久久中文字幕| 久久久精品区| 欧美激情综合| 亚洲精品日韩久久| 欧美在线亚洲| 欧美日韩精品免费观看视欧美高清免费大片| 亚洲自拍另类| 在线成人动漫av| 69精品国产久热在线观看| 麻豆精品在线观看| 久久亚洲电影| 免费视频最近日韩| 99久久精品网站| 久久午夜影院| 日本视频中文字幕一区二区三区| 久久91导航| 婷婷成人av| 国产中文字幕一区二区三区| 欧美在线首页| 久久av网站| 麻豆91小视频| 日本中文字幕视频一区| 999国产精品999久久久久久| 精品视频在线你懂得| 精品一区二区三区在线观看视频| 久久久久美女| 国产精品久久久久久模特 | 日韩欧美网址| 日韩理论视频| 国产精品伦一区二区| 国产 日韩 欧美 综合 一区| 国产盗摄——sm在线视频| 国产一区二区三区网| 日韩精品1区2区3区| 亚洲丝袜啪啪| 中文字幕av亚洲精品一部二部| 欧美一级网址| 日韩精品首页| 欧美一区=区| 日韩黄色在线观看| 欧美亚洲三级| 国产精品白浆| 国产一区二区三区亚洲| 日韩福利视频网| 欧美二区视频| 四虎精品一区二区免费| 国产aⅴ精品一区二区三区久久| 少妇精品导航| 国产视频亚洲| 欧美成人日韩| 久久国产精品久久久久久电车| 国产欧美自拍一区| 黑人精品一区| 蜜臀精品久久久久久蜜臀| 日韩久久99| 欧美激情日韩| 精品国产乱码久久久| 亚洲永久字幕| 久久免费福利| 欧美日韩国产综合网| 91嫩草精品| 日韩国产激情| 欧美日韩少妇| 中文字幕亚洲精品乱码| 午夜精品成人av| 水野朝阳av一区二区三区| 国产精品久久久久77777丨| 999国产精品| 久久精品97| 国产极品模特精品一二| 亚洲精品少妇| 中文在线不卡| 亚洲精品在线影院| 精品精品99| 毛片在线网站| 一区二区三区四区日本视频| 日本а中文在线天堂| 日韩欧美精品| 午夜久久久久| 日韩一区免费| 一级成人国产| 欧美国产精品| 欧美亚洲国产激情| 日韩精品午夜视频| 精品视频91| 蜜桃久久精品一区二区| 亚洲不卡av不卡一区二区| 天堂成人国产精品一区| 国产亚洲欧洲| 免费看精品久久片| 日韩精品福利一区二区三区| 成人三级高清视频在线看| 午夜在线一区| 九色porny丨国产首页在线| av一区在线| 国产成人精品一区二区三区视频 | 亚洲免费网址| 免费av一区| 国产在线观看www| 99久久夜色精品国产亚洲1000部| 免费精品国产| 97精品视频在线看| 美日韩一区二区三区| 香蕉视频亚洲一级| 久久国产精品亚洲77777| 精品91福利视频| www.九色在线| 亚洲精品在线二区| 国产情侣一区| 日韩欧美另类一区二区| 亚洲欧美日韩在线观看a三区| 国产日韩一区二区三区在线 | 视频一区国产视频| 国产欧美一区二区三区国产幕精品 | 日韩欧美在线中字| 欧美/亚洲一区| 国产高清精品二区| 日韩专区欧美专区| 国产亚洲毛片在线| 国产三级一区| 丝袜美腿一区二区三区| 国产乱码午夜在线视频| 欧美手机在线| 久久高清免费观看| 久久精品二区三区| 亚洲午夜国产成人| a天堂资源在线| 亚洲精品系列| 9色精品在线| 精品三级国产|