u
ubomjOct. 30, 2020, 5:52 a.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, 9:31 a.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, 6:57 a.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
GI

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

  • Result:60points,
  • Rating points-1
t

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

  • Result:70points,
  • Rating points1
LD

C++ - Тест 003. Условия и циклы

  • Result:57points,
  • Rating points-2
Last comments
VR

QML - Lesson 016. SQLite database and the working with it in QML Qt

Помогите, пожалуйста. У меня похожая задача, но я в qml слой долен передать не чистый запрос, а со сложной обработкой, поэтому у меня в С++ слое есть иерархия классов, которая имитирует бд и зап…
e
  • eviza
  • Nov. 16, 2020, 4:32 a.m.

Qt/C++ - Tutorial 083. Creating a dynamic library and connecting it to another project

здравствуйте! при компиляции библиотеки выскакивает окно особая программа( не удалось найти программу, укажите путь к ней), и в папке debug создается файл .dll, а .lib нет. подскажите…
IB

Data encryption by RSA algorithm in Qt with public and private keys without binding to OpenSSL

Библиотека подключилась нормально, только на выводе из первого примера выходит пустое сообщение, вместо "test message" просто "". Никаких ошибок не выдает.
VS

Qt WinAPI - Lesson 002. How to make win installer for Qt apllication?

Можно ли как-то однозначно (не проверяя) выяснить, запустится ли программа в windows 7? И как быть с разрядностью уже и просто в w10 (32\64)?
DT

Django - Tutorial 036. How to add authentication through social networks. VKontakte

Возможно, автор прочитает. Делал авторизацию с помощью ВК по книге Дронова. Выдает ошибку "Backend not found". Стал гуглить, нашел вашу статью, вроде почти то же самое (оно и понятно, документа…
Now discuss on the forum

Разный масштаб в формах и при запуске

Сврестайте все в один лэйаут (Выбирите окно и нажмити сверху на голубой квадратик из 9 голубфх квадратиков)

Обращение к ячейке таблицы

Вам нужно наследоваться от QAbstractTableModel, выбрать в каких контейнерах и как будите хранить данные и уже у них по индексу будите получать данные. Вот под рукой пример был на питоне, на…

Отправка JSON

postData.addQueryItem("data", doc.toJson(QJsonDocument::Compact).toStdString().c_str()); а почему так? попробуйте эту строку убрать, а эту запись: { "Array": [ t…
DK

QTableView не становится в редактирование

балин, вот я, конечно, "молодец". минус 5 часов, из-за того, что не поставил в модели флаги. Qt::ItemFlags UserModel::flags(const QModelIndex &index) const{ Qt::ItemFlags flags = Tre…

QSqlTableModel - Как добавить картинки в таблицу, чтобы они отражались в диалоговом окне, но не были частью модели

Ну тогда в этом столбце указывайте пути на несколько картинок
About
Services
© EVILEG 2015-2020
Recommend hosting TIMEWEB