在保持 HTML 样式的同时编写 Django 表单

Posted

技术标签:

【中文标题】在保持 HTML 样式的同时编写 Django 表单【英文标题】:Writing a Django Form while keeping HTML styling 【发布时间】:2021-09-28 10:58:48 【问题描述】:

我有一个手动创建的 Django 表单,以保持样式的格式,但我意识到该表单受到多个输入的影响,并且手动更改每个输入花费的时间太长。

我还可以使用 form.as_p 自动生成表单,但我丢失了下面的 html 样式格式。有没有一种简单的方法可以代替手动更改每个输入?

这是我试图保留的原始 HTML 模板

        </button>
          <div class="form-outline mb-4">
            <input
              type="text"
              id="businessName"
              class="form-control"
              name="businessName"
            />
            <label class="form-label" for="typeText"
              >Legal Business Name</label>
          </div>

这是有效的 Django 表单:

      % if submitted %
      Your forms has been submitted
      % else %
      <form method="post">
        % csrf_token %
         form.as_p 
        <!-- Submit button -->
        <button
          type="submit"
          class="btn btn-primary btn-block mb-4"
          id="btn"
        >
          Submit
        </button>

      </form>

这里是views.py

def add_form(request):
    submitted=False
    if request.method == 'POST':
        form = infoForm(request.POST)
        if form.is_valid():
            form.save()
            return HttpResponseRedirect('/?submitted=True')
    else:
        form = infoForm()
        if 'submitted' in request.GET:
            submitted=True
    return render(request, 'template/template.html','form':form, 'submitted':submitted)

这是表格

class infoForm(ModelForm):
    class Meta:
        model = Info
        fields = ['businessName']

这是我尝试过的:

                    <div class="form-outline mb-4">
                        <input type="text" class="form-control" name="businessName" % if form.is_bound %value=" form.businessName.value "% endif %>
                        <label class="form-label">Legal Business Name</label>
                    </div>
                    % for err in form.businessName.errors %
                        <small class="text-danger mb-2 ml-2"> err </small>
                    % endfor %

我的问题: 如何使用 form.as_p 轻松保持相同的 HTML 样式?

在这种情况下,属性所需的输入是什么?

【问题讨论】:

***.com/questions/401025/… 【参考方案1】:

这将是对 django 表单应用自定义样式的最快方法,这样您就可以让 django 处理表单,同时仍然使用您喜欢的 css 样式...

摘自我对How to markup form fields with in Django的回答

class MyForm(forms.Form):
    myfield = forms.CharField(widget=forms.TextInput(attrs='class': 'myfieldclass'))

class MyForm(forms.ModelForm):
    class Meta:
        model = MyModel

    def __init__(self, *args, **kwargs):
        super(MyForm, self).__init__(*args, **kwargs)
        self.fields['myfield'].widget.attrs.update('class': 'myfieldclass')

class MyForm(forms.ModelForm):
    class Meta:
        model = MyModel
        widgets = 
            'myfield': forms.TextInput(attrs='class': 'myfieldclass'),
        

originally answered

编辑 1:添加标签样式

1 通过上述方法设置类 例如:

self.fields['some_field'].widget.attrs.update('class': 'some_class')`

2 选择该类的标签并设置样式

.that_some_class label
    font-size: large;

【讨论】:

标签怎么样,如何添加类? 在编辑中添加...请注意,该样式一次应用于所有标签。在大多数情况下都可以。如果要选择特定标签,则必须渲染每个表单属性以单独设置样式

以上是关于在保持 HTML 样式的同时编写 Django 表单的主要内容,如果未能解决你的问题,请参考以下文章

django初学教程 投票应用 06 添加样式和图片

如何将样式添加到 base.html:Django 框架?

Django 在自定义 404 页面上传输具有 MIME 类型 text/html 的样式表

Python解决Django Admin管理界面样式表(CSS Style)丢失问题

关于django继承后网页样式消失的问题

html 放大时图形不会向上扩展.svg大小可以移动到样式表,但img大小必须保持内联。