首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无法在django中将单选按钮设置为必需

无法在django中将单选按钮设置为必需
EN

Stack Overflow用户
提问于 2017-01-10 00:45:23
回答 1查看 2K关注 0票数 1

我使用django小部件调整了以下单选按钮html (我不需要使用这个库,并且可以使用任何可行的方法):

代码语言:javascript
复制
{% for choice in seeking_form2.disaster_recovery %}
                          <div class="radio radio-primary radio-inline">
                           {{ choice.tag|attr:"required" }}
                            <label for='{{ seeking_form2.disaster_recovery.auto_id }}_{{ forloop.counter0 }}'>{{ choice.choice_label }}</label>
                          </div>
                          {% endfor %}

它应该创建如下所示的收音机:

代码语言:javascript
复制
<input id="id_disaster_recovery" name="disaster_recovery" type="radio" value="2" required>

我的模型看起来:

代码语言:javascript
复制
BOOL_CHOICES = ((True, 'Yes'), (False, 'No'))
disaster_recovery = models.BooleanField(choices=BOOL_CHOICES, default=False, )

我的表格看起来是:

代码语言:javascript
复制
class MyForm(forms.ModelForm):

    class Meta:
        model = MyModel
        widgets = {
            'disaster_recovery': forms.RadioSelect(), 
        }

我知道错误:

'SafeText‘对象没有属性'as_widget’

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-01-10 00:54:24

如果我正确地理解了您的问题,您应该在表单中而不是在模板或模型中覆盖这一点。

代码语言:javascript
复制
class MyModelForm(..):
    disaster_recovery = forms.ChoiceField(choices=BOOL_CHOICES, widget=forms.RadioSelect(), required=True) #Default is dropdown

现在,您可以简化HTML以呈现无线电按钮。

在这里可以找到更多的上下文。

要将HTML必需的属性添加到现有的表单中,您可以这样做:

代码语言:javascript
复制
class MyForm(forms.ModelForm):

    class Meta:
        model = MyModel
        widgets = {
            'disaster_recovery': forms.RadioSelect(attrs={"required": "required"}), 
        }

这是相关的关于自定义属性的文档

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41559454

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档