u
ubomj30. Oktober 2020 05:52

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

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

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 -> проверяем форму и сохраняем только после полного заполнения

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

7
Илья Чичак
  • 30. Oktober 2020 06:01

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

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

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

        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
      • 30. Oktober 2020 09:31
      • (bearbeitet)

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

          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)
      
        Илья Чичак
        • 31. Oktober 2020 05:39

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

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

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

          u
          • 31. Oktober 2020 06:00

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

            Илья Чичак
            • 31. Oktober 2020 06:57
            • (bearbeitet)
            • Die Antwort wurde als Lösung markiert.

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

              u
              • 31. Oktober 2020 07:05

              Спасибо

                Kommentare

                Nur autorisierte Benutzer können Kommentare posten.
                Bitte Anmelden oder Registrieren
                Letzte Kommentare
                ИМ
                Игорь Максимов5. Oktober 2024 07:51
                Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                d
                dblas55. Juli 2024 11:02
                QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                k
                kmssr8. Februar 2024 18:43
                Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                EVA
                EVA25. Dezember 2023 10:30
                Boost - statisches Verknüpfen im CMake-Projekt unter Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
                Jetzt im Forum diskutieren
                J
                JacobFib17. Oktober 2024 03:27
                добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
                JW
                Jhon Wick1. Oktober 2024 15:52
                Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
                КГ
                Кирилл Гусарев27. September 2024 09:09
                Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
                F
                Fynjy22. Juli 2024 04:15
                при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

                Folgen Sie uns in sozialen Netzwerken