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

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

19.06.2012, 13:57. Показов 5181. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru