如何禁用django表单中的模型字段

jam*_*mon 14 python django django-forms

我有这样的模型:

class MyModel(models.Model):
    REGULAR = 1
    PREMIUM = 2
    STATUS_CHOICES = ((REGULAR, "regular"), (PREMIUM, "premium"))
    name = models.CharField(max_length=30)
    status = models.IntegerField(choices = STATUS_CHOICES, default = REGULAR)

class MyForm(forms.ModelForm):
    class Meta:
        model = models.MyModel
Run Code Online (Sandbox Code Playgroud)

在视图中,我初始化一个字段并尝试使其不可编辑:

myform = MyForm(initial = {'status': requested_status})
myform.fields['status'].editable = False
Run Code Online (Sandbox Code Playgroud)

但是用户仍然可以更改该字段.

什么是实现我追求的真正方式?

Yuj*_*ita 40

第1步:禁用前端窗口小部件

使用HTML readonly属性:http:
//www.w3schools.com/tags/att_input_readonly.asp

disabled属性:http:
//www.w3.org/TR/html401/interact/forms.html#adef-disabled

您可以通过widget attrs属性注入任意HTML键值对:

myform.fields['status'].widget.attrs['readonly'] = True # text input
myform.fields['status'].widget.attrs['disabled'] = True # radio / checkbox
Run Code Online (Sandbox Code Playgroud)

步骤2:确保在后端有效禁用该字段

覆盖您的字段的干净方法,以便无论POST输入(有人可以伪造POST,编辑原始HTML等),您都可以获得已存在的字段值.

def clean_status(self):
    # when field is cleaned, we always return the existing model field.
    return self.instance.status
Run Code Online (Sandbox Code Playgroud)

  • 使用`self.instance.status`的诀窍非常好. (2认同)
  • 不好了.我试过了,"readonly"并没有什么区别.并且(http://www.w3schools.com/tags/att_input_readonly.asp)说'readonly属性可以与<input type ="text">或<input type ="password">一起使用.在我的情况下,它是一个选择或单选按钮.那么更多的想法? (2认同)

xle*_*eon 8

从 Django 1.9 开始:

from django.forms import Textarea

class MyModelForm(forms.ModelForm):
    class Meta:
        model = MyModel
        fields = '__all__'
        widgets = {'my_field_in_my_model': Textarea(attrs={'cols':80,'rows':1}),}             

    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        self.fields['my_field_in_my_model'].disabled = True
Run Code Online (Sandbox Code Playgroud)


dar*_*ren 6

您是否尝试过使用排除功能?

这样的事情

class PartialAuthorForm(ModelForm):
class Meta:
    model = Author
    fields = ('name', 'title')

class PartialAuthorForm(ModelForm):
class Meta:
    model = Author
    exclude = ('birth_date',)
Run Code Online (Sandbox Code Playgroud)

参考这里