u
ubomjOct. 30, 2020, 3:52 p.m.

Не проверять форму если нажали кнопку

Всем привет!
Имеем:

forms.py

class PostForm(forms.ModelForm):
    condition = forms.ChoiceField(widget=forms.RadioSelect, choices=CONDITION_CHOICES, label='Состояние', required=True)
    category = forms.ModelChoiceField(widget=forms.Select(attrs={'size':'10'}), queryset=Category.objects.all(), empty_label=None, label='Категория', required=True)
    subcategory1 = forms.ModelChoiceField(queryset=Subcategory1.objects.all(), required=True)
    subcategory2 = forms.ModelChoiceField(queryset=Subcategory2.objects.all(), required=True)

    class Meta:
        model = Advert
        fields = ('condition', 'title', 'description', 'category', 'subcategory1', 'subcategory2')

views.py

class PostCreateView(UpdateView):
    model = Post
    form_class = PostForm
    template_name = 'add.html'

    def get(self, request, *args, **kwargs):
        self.object = self.get_object()
        form_class = self.get_form_class()
        form = self.get_form(form_class)
        return self.render_to_response(self.get_context_data(form=form))

    def post(self, request, *args, **kwargs):
        self.object = self.get_object()
        form = self.get_form()

        #если нажимается кнопка draft
        if request.POST['submit']=='draft':
            form.instance.is_draft = 'True'
            self.object = form.save()
            return super().form_valid(form)
        else:
            pass

        return super().post(request, *args, **kwargs)



    def form_valid(self, form):
        form.instance.user = self.request.user
        self.object = form.save()
        return super().form_valid(form)



    def get_success_url(self):
        return reverse('index')

и шаблон с 2 кнопками

<button value="draft" type="submit" name="submit" class="button">Сохранить как черновик</button>
<button value="add" type="submit" name="submit" class="button">Добавить пост</button>

Как разобраться с проверками формы и сделать такое?:
если нажата кнопка draft -> не проверяем форму и просто сохраняем
если нажата кнопка add -> проверяем форму и сохраняем только после полного заполнения

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.
7

можно указать все поля, как required=False, а в методе clean сделать:

def clean(self):
    cleaned_data = super().clean()
    if 'add' in self.data:
        ... дополнительные проверки(что поля есть и все, что надо проверить дополнительно)
    return cleaned_data
u

что то не выходит((
попробовал вот так:

    def clean_title(self):
        title = self.cleaned_data.get('title')
        if 'title' in self.data:
            raise ValidationError("Title не заполнен")
        return title

При клике на кнопку add выдает Title не заполнен , а если нажать на draft кнопку = The Post could not be changed because the data didn't validate. и подсвечивает строку во вьюшке (self.object = form.save())

А пример дополнительной проверки можно?)) может я что то не то там пишу...

u
  • Oct. 30, 2020, 7:31 p.m.
  • (edited)

попробовал еще вот так:

    def clean(self):
        cleaned_data = super().clean()
        if 'add' in self.data:
            if not self.data['title']:
                raise forms.ValidationError(u'Обязательное поле')

        return cleaned_data

Ничего не происходит, но если убрать (if 'add' in self.data:) получается как и выше... при клике на add выдает !Обязательное поле - как и надо , а если нажать на draft кнопку = The Post could not be changed because the data didn't validate. и бросает на ошибку во вьюшке

 def post(self, request, *args, **kwargs):
        self.object = self.get_object()
        form = self.get_form()

        #если нажимается кнопка draft
        if request.POST['submit']=='draft':
            form.instance.is_draft = 'True'
            self.object = form.save() #<-------------------- вот сюда бросает
            return super().form_valid(form)
        else:
            pass

        return super().post(request, *args, **kwargs)

Возможно, если загуглить ошибку "could not be changed because the data didn't validate", можно было бы найти страницу, которая говорит, что надо вызвать метод "is_valid()" у формы? у вас же валидация происходит после вызова "save()"

Я бы посоветовал вам почитать документацию по формам Django - там есть ответы на большинство вопросов

ну и пока рано использовать UpdateView - если у вас не стандартная логика работы, Generic представления скрывают множество нюансов своей работы. использование сущностей более высокого уровня абстракции без понимания того, что происходит на нижних уровнях черевато "непонятными ошибками"

u

А если не UpdateView, то что посоветуете?

  • Oct. 31, 2020, 4:57 p.m.
  • (edited)
  • The answer was marked as a solution.

я бы посоветовал начать с функцией, потом классы (просто View), а потом, когда возникнет понимание, какие участки кода повторяются, можно переходить к Generic View.
generic view по сути просто View, в котором уже реализован тот код, который приходится писать каждый раз.

u

Спасибо

Comments

Only authorized users can post comments.
Please, Log in or Sign up
Timeweb

Let me recommend you the excellent hosting on which EVILEG is located.

For many years, Timeweb has been proving his stability.

For projects on Django I recommend VDS hosting

View Hosting
l
  • ldim
  • March 4, 2021, 10:57 p.m.

C ++ - Test 004. Pointers, Arrays and Loops

  • Result:100points,
  • Rating points10
l
  • ldim
  • March 4, 2021, 10:39 p.m.

C ++ - Test 004. Pointers, Arrays and Loops

  • Result:80points,
  • Rating points4
E

C ++ - Test 004. Pointers, Arrays and Loops

  • Result:80points,
  • Rating points4
Last comments
D

Django - Tutorial 001. Deploying a site on Django + PostgreSQL + Gunicorn + Nginx

А почему нельзя? Где можно об этом почитать? Киньте, пожалуйста, в меня ссылкой.
D

Django - Tutoral 049. Optimizing Django Performance with a Real Project

Огромное спасибо вам за статью! Для меня стали открытием select_related и prefetch_related
t
  • t1m4
  • Feb. 24, 2021, 1:56 p.m.

Django - Tutorial 052. Redefining a User Model

В данном случае я заходил под superuser но все равно не появлялись эти поля

Django - Tutorial 001. Deploying a site on Django + PostgreSQL + Gunicorn + Nginx

Поднял сервис с помощью systemd, вот по этому мануалу: https://habr.com/ru/post/501414/
t
  • t1m4
  • Feb. 23, 2021, 6:11 p.m.

Django - Tutorial 052. Redefining a User Model

А как дать ему эти права?
Now discuss on the forum
M

как добавить списки в список, которые созданы динамически

Привет всем! Смотрите новое: https://cazino.website/luchshie-kazino/ лучшие онлайн казино россии - За регистрацию предоставляют до 225 фриспинов бесплатно + 100% бонуса до 500$ на первый д…

Не отдаётся статика на виртуальной машине

В итоге выставил 775 на все файлы проекта и всё заработало. Но я не уверен, что так правильно.
P
  • Pisych
  • March 3, 2021, 12:06 p.m.

Вывод данных из связанных таблиц.

Не знаю, правильно ли... Но работает <body>{% for i in CatList %} <ul> <li><h3>{{i.title}}</h3></li>{% for j in ProdList %}<ul>{…
M

нужна помощь с проектом qt c++

дали задание, на несколько дней. собираюсь делать, но хотел бы получить помощь более опытных людей, чтобы подкорректировать себя и подстраховаться. каким образом это можно сделать? …

QScrollArea dynamically add QCheckBoxes

Всё правильно. Это просто спамер, который отправился в вечный бан.
About
Services
© EVILEG 2015-2020
Recommend hosting TIMEWEB