5

这是我的表单的定义:

class WorkflowForm(forms.Form):   
    new_user = forms.BooleanField(required=False)
    user = ModelChoiceField(queryset=User.objects.all())
    description = forms.CharField(required=False, widget=forms.Textarea)

如果选中new_user字段,我想禁用用户ModelChoiceField 。

那么是否可以在此类中定义一个字段对另一个字段的依赖关系,例如在我的情况下,modelchoicefield 依赖于是否检查了布尔字段?

4

2 回答 2

4

这是一个快速简单的,

<p>label for="id_new_user">New user:</label>
   <input type="checkbox" name="new_user" id="id_new_user" 
        onclick="javascript:toggleDiv('user_choice');" checked/></p> 

<p id="user_choice" style="display:none">        
    <label for="id_user">User:</label> 
    <select name="user" id="id_user">
        <option value="" selected="selected">---------</option>
        <option value="1">sam</option>
        <option value="2">usertest</option>
    </select>

表格.py

class WorkflowForm(forms.Form):   
    new_user = forms.BooleanField(required=False, initial=True)
    user = ModelChoiceField(queryset=User.objects.all())
    description = forms.CharField(required=False, widget=forms.Textarea)

    def __init__(self, user, *args, **kwargs):
        super(WorkflowForm, self).__init__(*args, **kwargs)
        self.fields['user'].queryset = User.objects.all()
        self.fields['user'].widget.attrs['style'] = 'display:none'
        self.fields['user'].widget.attrs['id'] = 'user_choice'
        self.fields['new_user'].widget.attrs['onclick'] = "javascript:toggleDiv('user_choice');"

模板

{{form.as_p}}

<script>
function toggleDiv(divId) {
    $("#"+divId).toggle(500);
}
</script>
于 2013-03-07T12:18:49.890 回答
0

由于您的表单不是 ModelForm,我假设您的意思是客户端:如果用户选中新用户复选框,则用户字段将被禁用。

你不能在 Python 端这样做,因为这一切都发生在浏览器中,而不是在服务器上。您需要使用 javascript。使用 jQuery 的示例:

    $(function() {
        $('#check').click(function() {
            var disable = $(this).is(':checked');
            $('#choice').attr('disabled', disable);
        });
    });

祝你好运。

于 2013-03-07T02:24:31.083 回答