|
7 / 5 / 1
Регистрация: 18.06.2012
Сообщений: 11
|
|
Многошаговый диалог с пользователем19.06.2012, 13:57. Показов 5221. Ответов 2
Метки нет (Все метки)
Здравствуйте, уважаемые коллеги!
С недавних пор самостоятельно изучаю Django и пытаюсь писать с его помощью скромный проектик. В процессе столкнулся со сложностью «идеологического характера», с которой, собственно, и обращаюсь к вам в надежде на подсказку опытных веб-разработчиков. Интуитивно чувствую, что вопрос весьма общий, но, к сожалению, затрудняюсь его внятно в общем виде сформулировать, поэтому попробую сделать это на маленьком искусственном примере (идейно близком к моей практической задаче). Пример задачи Допустим, требуется реализовать процедуру заказа товара в интернет-магазине, что предполагает примерно такую последовательность взаимодействий с пользователем:
Суть вопроса Попытаюсь сформулировать вопрос… Как в рамках веб-программирования и «в методологии Django» обеспечить сохранение промежуточного состояния и «целостности» процесса от начала процедуры (нажатия ссылки «оформить заказ») до получения результата (оформленный заказ), который можно сохранить в БД? Понимаю, что звучит ужасно; попытаюсь объяснить, разбив на более конкретные вопросы.
Дополнительные пояснения Хотел бы подчеркнуть, что для меня в данном случае более важным является не нахождение «какого попало» рабочего решения конкретной задачи, а понимание, как подобные задачи принято решать. Думаю, я вполне способен самостоятельно написать работающий код любым из упомянутых способов, но очень уж не хочется изобретать велосипед (уродливый, к тому же), а хочется верить в справедливость девиза: “There should be one-- and preferably only one --obvious way to do it.” ![]() Буду благодарен за любое конструктивное обсуждение, дельные подсказки и отсылки к полезным ресурсам. __ С уважением, Олег
0
|
|
| 19.06.2012, 13:57 | |
|
Ответы с готовыми решениями:
2
Диалог с пользователем Создать, какой ни будь диалог с пользователем через def |
|
61 / 58 / 12
Регистрация: 15.06.2012
Сообщений: 149
|
||
| 19.06.2012, 22:07 | ||
Добавлено через 13 минут Еще данную проблему можно решить просто выслав одну HTML страницу со скрытыми формами и управлять процессом через JS (что бы он скрывал и показывал нужные формы).
1
|
||
|
7 / 5 / 1
Регистрация: 18.06.2012
Сообщений: 11
|
|||||
| 20.06.2012, 00:44 [ТС] | |||||
|
Rikkit, спасибо за ответы!
![]() По второму пункту не поспоришь. Тут у нас вариантов, в общем-то, не много: либо хранить данные в сессии, либо сохранять их в более или менее временном виде в БД. Вопрос в том, насколько Django помогает справиться с этой задачей. Надеюсь, в эту тему забредут «практикующие джангисты» и поделятся опытом, какого рода объекты в данном случае уместно хранить в сессии (подозреваю, что экземпляры ModelForm после валидации, но до сохранения). С интерпретацией ответов 1 и 3 возникают проблемы. Если судить по следующему утверждению (по ссылке выше) —
На одну наработку, очень похожую на то, что мне нужно, я уже набредал: это Form wizard. Проблема в том, что в моей задаче последовательность форм не предопределена, а должна подчиняться некоторой взаимозависимой логике. Похожая ситуация обсуждается в заметке Multi-Step Forms in Django, но её автор решает более скромную задачу: всего две формы, вторая из которых зависит от первой. Проблема, на мой взгляд, заключается в том, что приходящие в голову «наколеночные» решения крайне плохо масштабируются при увеличении числа форм и усложнении логики взаимосвязи. Если делать всё в рамках одного view (в терминологии Django, не MVC!), то при десятке форм это будет монструозное создание (что, вроде бы, нехорошо). Если обрабатывать каждую форму в разных view, то, кажется, возникают большие проблемы с DRY-принципом и «ограничением ответственности», т.к. каждое из этих view (прошу прощения за этот навязчивый англицизм, но слово «представление» кажется мне ещё менее удобным) должно в этом случае «знать» многое о логике всего процесса (последовательность шагов, предварительные требования (prerequisites) по данным к предыдущим шагам, метод хранения временных данных в переменных сессии и т.п.). Если я не ошибаюсь, при использовании разных URL для разных шагов — перед обработкой каждого HTTP-запроса нужно проверять, соответствует ли текущее состояние промежуточных данных запрошенному шагу (как минимум, пройдены ли предыдущие шаги). А ведь хочется ещё, конечно, и давать возможность пользователю вернуться на предыдущие шаги… А как потом это дело поддерживать в случае изменения требований (которое в этом месте весьма вероятно) — вообще подумать страшно. P.S.
0
|
|||||
| 20.06.2012, 00:44 | |
|
Помогаю со студенческими работами здесь
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
|