【银角大王——Django课程——BootStrap父类样式】

ModelForm可以帮助我们生成HTML标签

class UserModelForm(forms.ModelForm):

    name=forms.CharField(min_length=3,label="用户名")
  
    class Meta:
        model = models.UseInfo
        fields = ["name","password","age","account","from_time","depart","gender"]

form=UserModelForm()

{{form.name}}   #普通的input框
{{form.password}}  #普通的input框
......

定义BootStrap插件来布局样式

方式一: 使用widgets={ }
#modelForm实例
from django import forms

class UserModelForm(forms.ModelForm):
    ######################################
    #定义其他的校验
    name=forms.CharField(min_length=3,label="用户名")
    #......



    class Meta:
        model = models.UseInfo
        fields = ["name","password","age","account","from_time","depart","gender"]
        #定义插件
        widgets={
            "name":forms.TextInput(attrs={"class":"form-control"}),
            "password": forms.PasswordInput(attrs={"class": "form-control"}),
方式二:使用widget=forms.TextInput(attrs={“class”: “form-control”})
#modelForm实例
from django import forms

class UserModelForm(forms.ModelForm):
    #定义其他的校验
    name=forms.CharField(
    min_length=3,
    label="用户名"
    #定义插件————用属性
	widget=forms.TextInput(attrs={"class": "form-control"})

)

    class Meta:
        model = models.UseInfo
        fields = ["name","password","age","account","from_time","depart","gender"]
      
{{form.name}}   #bootstrap样式的input框
{{form.password}}  #bootstrap样式的input框
......
方式三:重新定义的init方法,批量设置
#modelForm实例
from django import forms

class UserModelForm(forms.ModelForm):
    ######################################
    #定义其他的校验
    name=forms.CharField(min_length=3,label="用户名")
    #......



    class Meta:
        model = models.UseInfo
        fields = ["name","password","age","account","from_time","depart","gender"]
     
    def __init__(self,*args,**kwargs):
        super().__init__(*args ,**kwargs)
        #循环ModelForm的找到的所有插件,添加了class=“form-control”样式
        for name ,field in self.fields.items():
            field.widget.attrs = {"class":"form-control","placeholder":field.label}
方式四:自定义一个bootstrap父类

在这里插入图片描述

(1)代码如下:
#自定义bootstrap样式组件
from django import forms

class BootStrapModelForm(forms.ModelForm):
   
    def __init__(self,*args,**kwargs):
        super().__init__(*args ,**kwargs)
        #循环找到所有插件,添加了class=“form-control”样式
        for name ,field in self.fields.items():
          #字段中有属性,保留原来的属性,没有属性,才添加
            if field.widget.attrs:
                #有的话直接设置值
                field.widget.attrs["class"] = "form-control"
                field.widget.attrs["placeholder"] = field.label
                
            else:
                #没有的话直接赋值一个字典,因为attrs本身就是一个字典
                field.widget.attrs = {
                    "class":"form-control",
                    "placeholder":field.label
                }
(2)使用——在views中导入,然后再model中继承

在这里插入图片描述
在这里插入图片描述

视图分开存放

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

喜欢下雨t

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值