Define css class in django Forms

前端 未结 13 690
南旧
南旧 2020-11-27 10:11

Assume I have a form

class SampleClass(forms.Form):
    name = forms.CharField(max_length=30)
    age = forms.IntegerField()
    django_hacker = forms.Boolea         


        
相关标签:
13条回答
  • 2020-11-27 10:36

    You can try this..

    class SampleClass(forms.Form):
      name = forms.CharField(max_length=30)
      name.widget.attrs.update({'class': 'your-class'})
    ...
    

    You can see more information in: Django Widgets

    0 讨论(0)
  • 2020-11-27 10:37

    As it turns out you can do this in form constructor (init function) or after form class was initiated. This is sometimes required if you are not writing your own form and that form is coming from somewhere else -

    def some_view(request):
        add_css_to_fields = ['list','of','fields']
        if request.method == 'POST':
            form = SomeForm(request.POST)
            if form.is_valid():
                return HttpResponseRedirect('/thanks/')
        else:
            form = SomeForm()
    
        for key in form.fields.keys():
            if key in add_css_to_fields:
                field = form.fields[key]
                css_addition = 'css_addition '
                css = field.widget.attrs.get('class', '')
                field.widget.attrs['class'] = css_addition + css_classes
    
        return render(request, 'template_name.html', {'form': form})
    
    0 讨论(0)
  • 2020-11-27 10:39

    Here is Simple way to alter in view. add below in view just before passing it into template.

    form = MyForm(instance = instance.obj)
    form.fields['email'].widget.attrs = {'class':'here_class_name'}
    
    0 讨论(0)
  • 2020-11-27 10:39

    You could also use Django Crispy Forms, it's a great tool to define forms in case you'd like to use some CSS framework like Bootstrap or Foundation. And it's easy to specify classes for your form fields there.

    Your form class would like this then:

    from django import forms
    
    from crispy_forms.helper import FormHelper
    from crispy_forms.layout import Layout, Div, Submit, Field
    from crispy_forms.bootstrap import FormActions
    
    class SampleClass(forms.Form):
        name = forms.CharField(max_length=30)
        age = forms.IntegerField()
        django_hacker = forms.BooleanField(required=False)
    
        helper = FormHelper()
        helper.form_class = 'your-form-class'
        helper.layout = Layout(
            Field('name', css_class='name-class'),
            Field('age', css_class='age-class'),
            Field('django_hacker', css-class='hacker-class'),
            FormActions(
                Submit('save_changes', 'Save changes'),
            )
        )
    
    0 讨论(0)
  • 2020-11-27 10:43

    Here is a variation on the above which will give all fields the same class (e.g. jquery nice rounded corners).

      # Simple way to assign css class to every field
      def __init__(self, *args, **kwargs):
        super(TranslatedPageForm, self).__init__(*args, **kwargs)
        for myField in self.fields:
          self.fields[myField].widget.attrs['class'] = 'ui-state-default ui-corner-all'
    
    0 讨论(0)
  • 2020-11-27 10:46

    Yet another solution that doesn't require changes in python code and so is better for designers and one-off presentational changes: django-widget-tweaks. Hope somebody will find it useful.

    0 讨论(0)
提交回复
热议问题