Форум программистов, компьютерный форум, киберфорум
Python: Web
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/25: Рейтинг темы: голосов - 25, средняя оценка - 4.80
 Аватар для PureVirtual
7 / 5 / 1
Регистрация: 18.06.2012
Сообщений: 11

Многошаговый диалог с пользователем

19.06.2012, 13:57. Показов 5221. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, уважаемые коллеги!

С недавних пор самостоятельно изучаю Django и пытаюсь писать с его помощью скромный проектик. В процессе столкнулся со сложностью «идеологического характера», с которой, собственно, и обращаюсь к вам в надежде на подсказку опытных веб-разработчиков. Интуитивно чувствую, что вопрос весьма общий, но, к сожалению, затрудняюсь его внятно в общем виде сформулировать, поэтому попробую сделать это на маленьком искусственном примере (идейно близком к моей практической задаче).

Пример задачи
Допустим, требуется реализовать процедуру заказа товара в интернет-магазине, что предполагает примерно такую последовательность взаимодействий с пользователем:
  1. запросить личные данные (ФИО, контакты и т.п.);
  2. запросить способ доставки (курьер/почта/самовывоз…);
  3. запросить адрес доставки или предложить выбор ближайшего пункта самовывоза (в зависимости от выбранного способа доставки).
Думаю, для иллюстрации этого хватит. Существенными являются следующие обстоятельства:
  • процедура состоит из нескольких шагов, требующих пользовательского ввода;
  • последующие шаги существенно зависят от данных, введённых на предыдущих;
  • в процессе накапливаются промежуточные данные, но полноценный объект (заказ) может быть получен лишь по окончании всей процедуры.

Суть вопроса
Попытаюсь сформулировать вопрос… Как в рамках веб-программирования и «в методологии Django» обеспечить сохранение промежуточного состояния и «целостности» процесса от начала процедуры (нажатия ссылки «оформить заказ») до получения результата (оформленный заказ), который можно сохранить в БД? Понимаю, что звучит ужасно; попытаюсь объяснить, разбив на более конкретные вопросы.
  • Стоит ли реализовать всю процедуру в рамках одного view (обрабатывающего данные из разных форм, хранящего промежуточные данные, в том числе, информацию о том, какие шаги уже пройдены, и формирующего соответствующие веб-формы) либо в виде набора отдельных view для каждого шага (или даже каждого варианта каждого шага)?
  • Где хранить промежуточные данные (например, адрес доставки, который должен быть в итоге привязан к заказу, но соответствующего объекта ещё нет в БД)?
  • Если делать несколько view доступных по разным URL, то как контролировать целостность процесса (например, что пользователь не перешёл к произвольному шагу, введя его URL или воспользовавшись кнопкой браузера «назад»)?

Дополнительные пояснения
Хотел бы подчеркнуть, что для меня в данном случае более важным является не нахождение «какого попало» рабочего решения конкретной задачи, а понимание, как подобные задачи принято решать. Думаю, я вполне способен самостоятельно написать работающий код любым из упомянутых способов, но очень уж не хочется изобретать велосипед (уродливый, к тому же), а хочется верить в справедливость девиза: “There should be one-- and preferably only one --obvious way to do it.”

Буду благодарен за любое конструктивное обсуждение, дельные подсказки и отсылки к полезным ресурсам.
__
С уважением,
Олег
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
19.06.2012, 13:57
Ответы с готовыми решениями:

Диалог с пользователем
Напишем программу, которая сумеет провести с пользователем короткий, более или менее осмысленный диалог. Сначала программа спрашивает...

Диалог с пользователем
Напишем программу, которая сумеет провести с пользователем короткий, более или менее осмысленный диалог. Сначала программа спрашивает...

Создать, какой ни будь диалог с пользователем через def
value = 0 result = 0 while True: value = input("Стоимость товара, руб:") if value == "": break else: ...

2
61 / 58 / 12
Регистрация: 15.06.2012
Сообщений: 149
19.06.2012, 22:07
Цитата Сообщение от PureVirtual Посмотреть сообщение
  • Стоит ли реализовать всю процедуру в рамках одного view (обрабатывающего данные из разных форм, хранящего промежуточные данные, в том числе, информацию о том, какие шаги уже пройдены, и формирующего соответствующие веб-формы) либо в виде набора отдельных view для каждого шага (или даже каждого варианта каждого шага)?
  • Где хранить промежуточные данные (например, адрес доставки, который должен быть в итоге привязан к заказу, но соответствующего объекта ещё нет в БД)?
  • Если делать несколько view доступных по разным URL, то как контролировать целостность процесса (например, что пользователь не перешёл к произвольному шагу, введя его URL или воспользовавшись кнопкой браузера «назад»)?
К несчастью я не являюсь программистом на django, но вопросы эти кажутся для меня общими (имею опыт работы с HMVC), попытаюсь ответить.
  1. Контроллер может быть один, но виды должны быть разные. Либо один вид и в него вставки видов разные
  2. Промежуточные данные хранят в сессии
  3. Контроллер пускай будет один, считывает сессию и определяет этап

Добавлено через 13 минут
Еще данную проблему можно решить просто выслав одну HTML страницу со скрытыми формами и управлять процессом через JS (что бы он скрывал и показывал нужные формы).
1
 Аватар для PureVirtual
7 / 5 / 1
Регистрация: 18.06.2012
Сообщений: 11
20.06.2012, 00:44  [ТС]
Rikkit, спасибо за ответы!

Цитата Сообщение от Rikkit Посмотреть сообщение
К несчастью я не являюсь программистом на django, но вопросы эти кажутся для меня общими
Безусловно, проблема достаточно общая и аналогичные вопросы должны возникать в любой системе с веб-интерфейсом, но подозреваю, что в разных фреймворках они традиционно решаются слегка по-разному.

Цитата Сообщение от Rikkit Посмотреть сообщение
(имею опыт работы с HMVC)
Насколько я понял, в Django схема MVC реализована как “MTV” (Model-Template-View), причём элементы, стоящие в аббревиатуре на соответствующих местах, транслируются друг в друга не напрямую, так что, как минимум, терминологическая путаница нам с Вами обеспечена.

По второму пункту не поспоришь. Тут у нас вариантов, в общем-то, не много: либо хранить данные в сессии, либо сохранять их в более или менее временном виде в БД. Вопрос в том, насколько Django помогает справиться с этой задачей. Надеюсь, в эту тему забредут «практикующие джангисты» и поделятся опытом, какого рода объекты в данном случае уместно хранить в сессии (подозреваю, что экземпляры ModelForm после валидации, но до сохранения).

С интерпретацией ответов 1 и 3 возникают проблемы. Если судить по следующему утверждению (по ссылке выше) —
Цитата Сообщение от Django FAQ
Where does the “controller” fit in, then? In Django’s case, it’s probably the framework itself: the machinery that sends a request to the appropriate view, according to the Django URL configuration.
то выходит, что в идеологии Django функции контроллера в основном должен брать на себя сам фреймворк. Это для меня один из поводов надеяться, что «идеологически верное» решение уже существует, и не придётся «изобретать велосипед».

На одну наработку, очень похожую на то, что мне нужно, я уже набредал: это Form wizard. Проблема в том, что в моей задаче последовательность форм не предопределена, а должна подчиняться некоторой взаимозависимой логике. Похожая ситуация обсуждается в заметке Multi-Step Forms in Django, но её автор решает более скромную задачу: всего две формы, вторая из которых зависит от первой.

Проблема, на мой взгляд, заключается в том, что приходящие в голову «наколеночные» решения крайне плохо масштабируются при увеличении числа форм и усложнении логики взаимосвязи. Если делать всё в рамках одного view (в терминологии Django, не MVC!), то при десятке форм это будет монструозное создание (что, вроде бы, нехорошо). Если обрабатывать каждую форму в разных view, то, кажется, возникают большие проблемы с DRY-принципом и «ограничением ответственности», т.к. каждое из этих view (прошу прощения за этот навязчивый англицизм, но слово «представление» кажется мне ещё менее удобным) должно в этом случае «знать» многое о логике всего процесса (последовательность шагов, предварительные требования (prerequisites) по данным к предыдущим шагам, метод хранения временных данных в переменных сессии и т.п.). Если я не ошибаюсь, при использовании разных URL для разных шагов — перед обработкой каждого HTTP-запроса нужно проверять, соответствует ли текущее состояние промежуточных данных запрошенному шагу (как минимум, пройдены ли предыдущие шаги). А ведь хочется ещё, конечно, и давать возможность пользователю вернуться на предыдущие шаги… А как потом это дело поддерживать в случае изменения требований (которое в этом месте весьма вероятно) — вообще подумать страшно.

P.S.
Цитата Сообщение от Rikkit Посмотреть сообщение
Еще данную проблему можно решить просто выслав одну HTML страницу со скрытыми формами и управлять процессом через JS (что бы он скрывал и показывал нужные формы).
Эм… переложить часть работы на client side — конечно, соблазнительно… но, честно говоря, я крайне слаб в JS и хотел бы прибегать к нему лишь в крайних случаях и в минимальных объёмах. В любом случае «лёгким» JS тут почти наверняка не обойтись, т.к. на промежуточных шагах всё-таки может быть желательным сохранение части данных в БД (например, данных, относящихся к заказчику, а не конкретному заказу), и почти всегда потребуется извлекать различные (в зависимости от предыдущих шагов) данные из БД, а это уже AJAX, «высший пилотаж» и вообще несколько другой подход к разработке веб-приложения в целом.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
20.06.2012, 00:44
Помогаю со студенческими работами здесь

Диалог с пользователем
Помогите разобраться , пишу скрипт в первый раз Диалог с пользователем Ввести диапазон Структурированный вывод Вывод...

Диалог с пользователем
Подскажите пож,как в Swing организовать стандартное окно с функционалом "назад" "далее" "прервать". Смысл...

диалог с пользователем
нужно написать программу с оформлением примерно таким вопрос:"перечислите через запятую все ключевые слова,которые используются в...

Диалог с пользователем
Итак, через set /p прошу пользователя ввести некое значение, которое задаю переменной %p%. Теперь мне нужно проверить: если это значение...

Создать диалог с пользователем
*Создать диалог с пользователем, таким образом: -запрашивается вывод результат, с клавиатуры должен поступить ответ, если ответ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru