Архитектура ПО, MVC и бизнес-логика. Критика Django

Поділитися
Вставка
  • Опубліковано 2 лют 2025

КОМЕНТАРІ • 402

  • @slavchina_reviews
    @slavchina_reviews 5 років тому +310

    Какой же душевный у тебя контент. Как будто с корешем на кухне болтаю. Мне лично очень заходит такой подход, удачи в развитии канала!

    • @t0digital
      @t0digital  5 років тому +11

      Спасибо, очень приятно!

    • @xm4dn355x
      @xm4dn355x 5 років тому +1

      Тут сложно не согласиться)

    • @singirin
      @singirin 5 років тому +3

      Тема супер. После первого знакомства с джангой я как то неделю пытался найти в интернете куда же нужно пихать бизнес логику. Так и не нашёл кстати) Но пришёл к тому же способу как в видео

    • @t0digital
      @t0digital  5 років тому +3

      @@singirin отлично! Странно, что Django не даёт нормальных рекомендаций в своей же доке

    • @МишаАлексеев-я1ч
      @МишаАлексеев-я1ч 4 роки тому

      @@t0digital Да, отдельный респект за это, никогда так не было приятно слушать материал

  • @РодионСоловьев-к1ч
    @РодионСоловьев-к1ч 2 роки тому +12

    Такого понятного объяснения MVC я ещё нигде не встречал

  • @ola_amirova
    @ola_amirova 4 роки тому +6

    Уже 4 раз пересматриваю и возвращаюсь к этому видео, 20 минут концентрированной, крутой информации! Спасибо!

  • @canada946
    @canada946 5 років тому +7

    Отличное видео! Очень полезно и информативно. Теория ясна, теперь ждём видео с практикой модель-вью-контроллер. Не хватает таких видео, где всё архитектурно грамотно и красиво, чтобы понимать как оно происходит.

    • @t0digital
      @t0digital  5 років тому +1

      Обязательно будет живой пример. Спасибо!

    • @canada946
      @canada946 5 років тому

      Диджитализируй! АйТи студия а ещё если можно, расскажите как можно использовать одно приложение Джанго (не проект) в нескольких проектах, если такое вообще возможно. Как наоборот сделать (один проект, много приложений) понятно :)

  • @TeppopucT
    @TeppopucT 4 роки тому +7

    Очень полезно!
    Был бы тех диром, заставил бы всех джанговодов посмотреть этот ролик.
    Спасибо

  • @ДанилЕфимов-г9п
    @ДанилЕфимов-г9п Рік тому +2

    Так бы и сидел все время и слушал ваше объяснение. Очень интересно объясняете. Спасибо!

  • @k4m454k
    @k4m454k 5 років тому +46

    Единственный канал, где меня с экрана называли "Котаном". раньше......

    • @TheTruepikvic
      @TheTruepikvic 5 років тому +8

      Да, хороший был канал 😊

    • @kosatchev
      @kosatchev 5 років тому +4

      Да, что с котанами?

  • @dmmeteo
    @dmmeteo 5 років тому +3

    Вообще сами разработчики Джанго говорят что контроллеры в Джанго это скорей urls.py а бизнес логику рекомендуют писать в models.py. В компании которой я работаю сейчас, мы тоже используем подход с services & selectors(места для агрегации данных) и мы это унаследовали от Болгарский компании hacksoftware которая одна из первых описала стайлгайд для такого стиля архитектуры для Джанго;) и это подход достаточно удобен на практике)

  • @nikolay1944
    @nikolay1944 5 років тому +1

    Здравствуйте. Отличное видео. Слушать вас можно часами. Сам я работаю с Ruby и RoR. Недавно заинтересовался в джанге и сейчас уже делаю проекты и на RoR и на Джанге. Я был удивлен когда узнал, что в Джанге MVT архитектура. Действительно из-за этого код пишется то в view, то в моделях. Возможно изначально Джанга задумывалась не только как веб фреймворк. Поэтому здесь нет такого жёсткого разделения. В каждом проекте ты можешь тонко настроить всё под свои нужды. В рельсах хоть и MVC, но бизнес логику ты тоже пишешь в сервисах.
    Хотелось бы увидеть с вашей точки зрения топ проектов на Джанге на гитхабе с хорошим кодом. Спасибо.

  • @Geolimber
    @Geolimber 5 років тому

    Как раз вовремя. Начал проект на джанго и мучался вопросом куда бизнес логику писать. Как раз начитался противоречивых советов, что во вьюху/модель писать. Потом посоветовали вообще рест фреймворк. Взрыв мозга.
    А тут всё по делу и понятно, спасибо.

  • @mikhailfedorov4034
    @mikhailfedorov4034 2 роки тому +1

    Здравствуйте!
    Пишу свой первый проект и есть немного каши в голове. Если я создаю контроллер, который возвращает конкретную страницу участника блога с деталями, и в шаблоне во время использования template engine и обхода authors в цикле, использую {{ author.article_set.count }} то получается, что я делаю запрос в бд из шаблона, и это нарушение mvc(mtv) паттерна?

  • @Кантригоспел
    @Кантригоспел 5 років тому +7

    Спасибо, отличная тема!!!)
    Если подытожить, в джанго советуешь делать:
    1.модуль service - файлы (скрипты) с бизнес логикой (запросы к бд и другие работы с данными)
    2. views.py - контроллер
    3. Ну и шаблоны это понятно отображение (views из mvc)
    Так?)

    • @t0digital
      @t0digital  5 років тому +3

      Да, и models.py это ORM классы и возможно совсем чуть-чуть бизнес логики

  • @muratdautov7576
    @muratdautov7576 5 років тому

    Model-View-Controller (MVC, «Модель-Представление-Контроллер», «Модель-Вид-Контроллер») - схема разделения данных приложения, пользовательского интерфейса и управляющей логики на три отдельных компонента: модель, представление и контроллер - таким образом, что модификация каждого компонента может осуществляться независимо

  • @vkh5864
    @vkh5864 3 роки тому

    Лайк, на 1000% согласен! И про нейминг и про вопрос - где писать бизнес логику в Django

  • @ILMIX007
    @ILMIX007 5 років тому +3

    Спасибо, лайк. Жду новых видео про архитектуру и паттерны

  • @wandos777
    @wandos777 3 роки тому

    На самом деле стало понятно, как MVC укладывается в django ) а то поназывали там views это контроллер... бр, спасибо, что разъяснили!

  • @zamermen
    @zamermen 4 роки тому +2

    Спасибо, очень доступно объясняешь, кажется я начал кое что понимать)

    • @t0digital
      @t0digital  4 роки тому

      Отлично, рад, что полезно!

  • @toomanof
    @toomanof 5 років тому

    Давно сам задумывался о данном вопросе в Django. Сколько раз этот момент обсуждали с коллегами. Мы всю бизнес-логику выносим в фасады.

  • @JustDoit-bl6pq
    @JustDoit-bl6pq 5 років тому +4

    Есть ли ссылка на более подробное описание в примерах реализации services в django?

    • @t0digital
      @t0digital  5 років тому +7

      Ссылки нет. Думаю, разберём на живом примере как-нибудь

    • @nkhitrov
      @nkhitrov 5 років тому +5

      ua-cam.com/video/yG3ZdxBb1oo/v-deo.html

  • @gregn834
    @gregn834 5 років тому

    Кстати, давно уже задавался вопросом, где же в джанге бизнес прикручивать. Теперь знаю. Как раз вовремя видео подошло! Спасибо!

  • @hovharoyan3262
    @hovharoyan3262 10 місяців тому

    Здравствуйте спасибо за разъяснение!Подскажите пожалуйста есть пример кода на джанго которое можно посмотреть )

  • @senatortre7326
    @senatortre7326 5 років тому +1

    Как же вовремя это видео, когда пошел на курс по джанго... Очень хочется делать красиво. Хотелось бы подробнее с технической части, взглянуть на структуру проекта. Плохо понятно со скриншота, ну папочки там какие-то, и что?
    django-service-objects юзать стоит?
    В дзене питона вон говорят, что проще - лучше и вообще главное, чтоб работало.
    Не все наслышаны о MVC (тем более очевидно, раз в каждом 1ом проекте такие косяки), стоит развить эту тему! Помог начать задавать правильные вопросы, спасибо!=)

    • @senatortre7326
      @senatortre7326 5 років тому +1

      ua-cam.com/video/yG3ZdxBb1oo/v-deo.html
      многое поясняет данная лекция.

  • @maksimangerman6238
    @maksimangerman6238 2 роки тому

    Январь 2023 года. И Вы открыли мне глаза) спасибо Вам!)

    • @maksimangerman6238
      @maksimangerman6238 2 роки тому

      upd: И действительно очень ламповые и приятные выпуски.

  • @АлександрМельник-ч3ь

    по поводу модуля доставки вашего есть пару вопросов. - я правильно понял что его нужно оплачивать помесячно? (забыл оплатить и магазин не может принимать заказы?) - как происходит добавление новых служб доставки? (это делает уже тот кто приобрел программу? К примеру недавно мне пришлось делать интеграцию со службой доставки Стриж, и по-моему ее нет в списке вашего модуля. Или же в ежемесячную плату входят и любые доработки?) - для небольших магазинов я использую CMS MODx и не вижу ее в списке поддерживаемых. Пошел почитать как происходит интеграция и вижу что она на js. Каждая CMSка как правило уже содержит свои инструменты для оформления заказов, расчета стоимости и так далее. Каким образом информация о заказе, оформленном через ваш модуль будет взаимодействовать с уже имеющимися в MODx сущностями заказа, статусами состояния заказа и так далее? (при учете что как такого api у modx для решения этих задач нет) ну и плюс тот же вопрос - доработка модуля под конкретную задачу уже входит в ежемесячную сумму? Спасибо.

    • @t0digital
      @t0digital  4 роки тому +1

      _я правильно понял что его нужно оплачивать помесячно? (забыл оплатить и магазин не может принимать заказы?)_
      Да, сервис платный, без денег не работает:)
      _как происходит добавление новых служб доставки?_
      Что-то сложное - через нас, а свою простую курьерку или пункт выдачи можете добавить сами в личном кабинете.
      Modx модуля нет, интеграции под них соответственно тоже. Запросов на Modx большого количества тоже нет, так что не уверен, что будем делать в ближайшее время.
      Интегрировать всё на js не получится, информацию о доставке надо ведь сохранять в CMS. Плюс выгрузка заказов и тд. Полноценная интеграция это непросто.

    • @АлександрМельник-ч3ь
      @АлександрМельник-ч3ь 4 роки тому

      @@t0digital Спасибо, я видимо не совсем правильно понял суть. Считал, что это просто некий отдельный модуль, который будучи установлен на сайт работает обособленно и исключительно локально. Такие модули как правило имеют разовую фиксированную стоимость. А у Вас получается, что модуль это лишь некий клиент, работающий с вашим сервисом и данные хранятся на ваших серверах. Тогда понятно откуда стоимость в виде ежемесячной подписки. Удачи в его популяризации, выглядит эффектно и особенно порадовала приятная и понятная документация по api, что редко встретишь.

    • @t0digital
      @t0digital  4 роки тому

      @@АлександрМельник-ч3ь спасибо! Да, мы храним все тарифы и данные у себя, обновляем их и позволяем гибко настраивать. Помимо гибкости настройки это даёт большой буст в скорости работы - API служб доставки медленные и ненадежные, отваливаются часто (привет СДЭК), мы это решаем как раз за счет хранения данных у себя

  • @AlexBabinoff
    @AlexBabinoff 5 років тому

    ОЧЕ круто, ну вот теперь то наконец-то дошло (надеюсь)).

  • @spair2k
    @spair2k 5 років тому

    БлагоДарю за такую замечательную подачу материала. Хотелось бы в роликах увидеть подробности, как правильно организовывать архитектуру кода при написании простого приложения (или отдельной функции бизнес-логики) соблюдая принципы DRY.

    • @t0digital
      @t0digital  5 років тому +2

      покажу как-нибудь в живом примере, да!

  • @vladislavmikhailov
    @vladislavmikhailov 2 роки тому

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

  • @vsbff
    @vsbff 5 років тому +1

    Более того, должен быть слой контроллера, слой сервиса, слой репозитория, слой респонс-сервиса, и каждый друг для друга есть «чёрный ящик». Работаю по такой архитектуре со Spring и JavaEE (Jakarta EE), и все великолепно поддерживается. Однако, наговнокодить можно умудриться везде, если к тому душа лежит )

  • @zenovsergey
    @zenovsergey 5 років тому

    На восьмой минуте понял, что ничего не понятно, но, очень интересно. В любом случае, спасибо, Котан!

  • @vladyslavnazarenko
    @vladyslavnazarenko 4 роки тому

    Отличная информация и ее подача, все доступно и наглядно. Большое спасибо!

    • @t0digital
      @t0digital  4 роки тому

      Спасибо, рад, что полезно!

  • @Krasnolesye
    @Krasnolesye 10 місяців тому

    Спасибо за четкое, понятное объяснение. Молодца

  • @xander-on-the-earth
    @xander-on-the-earth 5 років тому

    Отличный канал! Суперская подача материала! Высокий уровень! Автору -- респект, котанам -- привет!

    • @t0digital
      @t0digital  5 років тому

      Спасибооо💪!

  • @cyber-doge
    @cyber-doge 5 років тому

    3:20 Сортировку массива перед показом можно в отображение запихнуть? (при условии что в бизнес модели этот массив отсортированный не используется)

    • @t0digital
      @t0digital  5 років тому +2

      Я думаю, что да, это может быть логикой отображения. Не все шаблонизаторы это поддерживают, поэтому можно перенести это в контроллер. Частые задачи контроллера это форматирование, сортировка данных, пришедших от модели, и затем уже передача их в отображение

    • @cyber-doge
      @cyber-doge 5 років тому

      @@t0digital Спасибо!

  • @dzianish6223
    @dzianish6223 3 роки тому

    Джавашные либы это Spring. Он из коробки даёт DI и некурильщик создает контроллер, ставит над ним аннотацию (в питоне это вроде декоратор) @Controller, создаёт интерфейс сервиса (без реализации), создаёт класс имплементирующий интерфейс сервиса и ставит над ним @Serivce. В классе контроллера создает поле типа интерфейса сервиса и ставит над ним аннотацию @Inject. Ну всё, дальше спринг делает магию DI при запуске.

  • @GrinRuslan
    @GrinRuslan 5 років тому

    Большое спасибо за видео. Было очень интересно и с именованием и хранением в services было ново и полезно.

    • @t0digital
      @t0digital  5 років тому

      Отлично! Рад, что полезно

  • @0682797
    @0682797 4 роки тому

    По поводу отсутствия в Django возможности обратиться к БД из шаблона: разве код {{ foo.bar_set.all }} в шаблоне не приведет к запросу?

  • @ЕленаМ-ц2ъ
    @ЕленаМ-ц2ъ Рік тому

    Класс! Наконец-то это ктото объяснил. Вы - спасение

  • @MADAHAKO
    @MADAHAKO 3 роки тому

    Хоспади, как же круто вы рассказываете!!! Спасибо!!

  • @jonsnow8178
    @jonsnow8178 5 років тому +4

    Если загуглить "Django API Domains", то можно найти трактат, где ребята пошли ещё дальше, чем просто services.
    Я до сих пор жалею, что слишком поздно о нем узнал. Есть у меня несколько проектов, где такой подход избавил бы от множества костылей.
    Но переходить от ForeignKey к UUID - это очень трудоемкая задача для уже готового проекта.

  • @dmitrytsmyh5971
    @dmitrytsmyh5971 4 роки тому

    Секундочку ...
    Т.е. в services описана общая логика запросов в БД, которая подходит и к вебу и к DRF?
    Звучит конечно интересно, но не является ли это множителем кода? Вьюшки работают с реквестами, сессиями и делают (в лучшем случае) по 1 запросу в БД.
    АПИ, там формы и страницы отличаются от веба, и андроиды-разработчики могут слать тебе скопом всю инфу, когда им удобно.
    Хотя, конечно, это придирки.) Дайте, плиз, какую ссылочку на гитхабе, где services, объединяют бизнез логику АПИ и веба.

    • @t0digital
      @t0digital  4 роки тому

      Принципиальной разница API и веба нет. Схема работы API - пришел запрос в контроллер (джанговый views), контроллер распарсил его, возможно проверил корректность данных в запросе, запросил данные в сервисах, получил их и вернул в JSON клиенту. Схема работы веба такая же, просто на последнем шаге данные вернутся не в JSON клиенту, а в template, который их вставит в HTML и клиенту улетит HTML с данными.

  • @qazaqbalasy916
    @qazaqbalasy916 Рік тому

    То есть в services пилить логику, а во views оставить только return render?

  • @Кантригоспел
    @Кантригоспел 5 років тому

    Спасибо за актуальное видео!))
    Как раз делаю проект на джанге.

    • @t0digital
      @t0digital  5 років тому

      models.py - это модели Django, отображающие структуру БД

    • @Кантригоспел
      @Кантригоспел 5 років тому

      @@t0digital еще несколько раз пересмотрел, чтоб понять mvc что такое и как в джанго это реализовано))

  • @АндрейРожнов-ш9к
    @АндрейРожнов-ш9к 4 роки тому

    Спасибо! Настолько все очевидно и логично, что даже странно, что кто то делает иначе!!!

    • @t0digital
      @t0digital  4 роки тому

      странно, но факт:)

  • @MOVxR32
    @MOVxR32 4 роки тому +1

    Здравствуйте, я тоже пришел к такому выводу и всю бизнес логику выносил в файл (пакет если он разрастается) под названием utils. Потому что в представлениях совсем не то место, а модели сильно распухают и плохо тестируются потом. Это надо пройти на своем опыте(!). Интересно было бы взглянуть на структуру этого пакета у Вас

    • @MOVxR32
      @MOVxR32 4 роки тому +1

      Название services мне нравится гораздо больше. Погуглил - это действительно очень распространенный подход а я дошел до него только после года фриланса и работы работы над приложениями за зарплалу. Как же многого мы (я) еще не знаем...

  • @hackroute
    @hackroute 4 роки тому

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

  • @nikolaymatveychuk6145
    @nikolaymatveychuk6145 5 років тому +12

    В отображении не должно быть логики - да, обычно когда такое говорят, имеют ввиду именно бизнес логику :) Это такое сокращение, которое обычно воспринимается как очевидное.
    Контроллер плохо называть клеем между (моделями) бизнес логикой и представлениями (отображением). У контроллера есть одна основная задача - обработать запрос. То есть ему надо принять решение о том, что хочет пользователь, выполнить нужные действия, и показать пользователю ответ. Иначе, если бы контроллер был клеем между моделями и представлениями, то по данному шаблону было бы запрещено отправлять модели с данными в представления, а нужно было бы их разбирать на массивы и отправлять только массивы.
    В контроллере запрещена работа с БД через ORM? :) То есть если пользователь запросил у сайта данные о своих покупках за последний месяц, то я не могу выполнить Order::find()->andWhere(список_условий)->all(), и мне надо это куда-то в статический метод моделей совать? Это неверное утверждение, я считаю... нет ничего плохого в том, чтобы контроллер запросил данные откуда ему угодно, главное, чтобы он эти данные сам не генерировал (не считал). Как я говорил, его задача в том, чтобы понять запрос, выполнить его, и отобразить необходимые данные (а идея о том, что там не должно быть запросов в БД скорее всего родилась из утверждения, что контроллер - это всего лишь клей без какой либо собственной функции).
    Насчёт записи данных - ну контроллер вполне может принять формы с данными, запустить в них процесс валидации, если он прошёл успешно, то рассовать данные по моделям и вызвать метод сохранения моделей. Под сохранением айфонов в БД это имелось ввиду? :) Если да, то в этом нет ничего преступного, потому что это всё ещё исключительно обработка запроса, и если тело запроса вдруг надо будет изменить для другого приложения, то и обработка этого запроса будет другой, а значит нам в любом случае именно эта логика будет мало полезна :)
    "не предлагает места, где писать бизнес логику" - эм :)) бизнес логику надо писать в моделях (yii, yii2 тоже не предлагают никаких других мест для неё), потому что именно там ей и место. Предполагается, что модель - это самый типичный объект парадигмы ООП, то есть сущность, которая соответствует объекту реального мира и имеет свои свойства и методы для работы с ним. Потому да, логику пишем исключительно на уровне моделей и именно в них самих. Если же нам нужна абстракция не настолько большая, как "модуль", но и не настолько детальная, как "модель", то для этого паттерн MVC можно расширить такой штукой как "Service layer" (паттерн такой), когда контроллер, обрабатывая запросы, дёргает не методы моделей, а вызывает функции сервисов, которые в свою очередь уже дёргают методы моделей. (АХАХА.... пишу сообщение во время просмотра видео, снимаю с паузы, а тут "для этого создаём свой слой Бизнес логики, называем его services"... ну вот тут согласен полностью xD только это не джавовая фишка такая, а полноценный паттерн)
    P.S. Судя по тому, что говорится в видео, у автора не совсем верное представление о том, что такое бизнес логика. :) Бизнес логика - это то, что с точки зрения пользователя происходит за кулисами (то, о чём он не просил, но что произошло в силу необходимости для бизнеса), при этом так, как контроллер лишь обрабатывает запрос, мы можем себе представить, что вместо него мы и посадили очень умного пользователя. Вот он решил купить телефон, что он сделает, если он умный?
    - Попросит "покажи мне список всех телефонов с ценой от 10к до 20к рублей"
    - Сохрани пожалуйста мой заказ и покажи что мне надо сделать, чтобы его получить (например оплатить, выбрать дату доставки и т.д.)
    - Сохрани [вот эти] дополнительные данные по заказу и отправь меня оплачивать заказ
    - Скажи всё ли ты правильно принял, когда и на каких условиях ждать мой заказ
    Вот всё это - это то, с чем контроллер обращается к уровню моделей :) И это не является бизнес логикой, а вот всё остальное, что делает система (например расчёт скидок, отправка писем, передача заявок в разные CRM системы и т.д.) - это уже бизнес логика.

    • @sivr5vs38
      @sivr5vs38 5 років тому

      Nikolay Matveychuk ну начнём с того, мадель, которую было бы правильнее называть activerecord которая не особо строго говоря и матчится с ооп, и очень сильно шлёт в задницу принцип единой ответсвенности и другие лучшие принципы ооп и хорошей архитектуры. И что делать в таком случае(фет модел) , если нужно обработать 5 моделей за один запрос? Устраивать ад зависимостей?) Или что произойдёт с приложением, если добавится 6 модель в запросе? Ну батенька, с такими моделями только про хорошую архитектуру и мечтать)
      P.S. Как вообще можно приводить в пример архитектуры с yii?)))

    • @nikolaymatveychuk6145
      @nikolaymatveychuk6145 5 років тому

      @@sivr5vs38 Ну модель - это не обязательно ActiveRecord. Модель это Model, а активрекорд - это её наследник, ещё и не прямой, кажется, а через несколько уровней :) Но если мы будем говорить даже про актив-рекорд, то я не вижу там особого нарушения принципа единой ответственности. Сначала надо понять, что активрекорд - это запись в хранилище данных, а точнее её объектный аналог, потому разные методы link, unlink, save и прочее, тут находятся вполне к месту. Не к месту тут только метод find вероятно, так как сильно выбивается из абстракции самого объекта. Я, разумеется, могу быть в чём-то неправ, ну тогда лучше рассмотреть конкретный случай нарушения принципа единой ответственности в активрекордах.
      Аргумент насчёт сложных связей тоже не понял. Если я за один запрос принимаю форму для 5-ти моделей, то, по идее эта форма может и реализовать методы работы с "подчинёнными" ей моделями в условиях этого запроса. Если же я принимаю форму для одной модели, но при её создании должны создаться ещё 4 с какими-то служебными данными, то этим как-раз должна заниматься основная модель, потому что без этих данных она не имеет смысла. Ну как я говорил, если мы видим, что работая с моделями мы постоянно вынуждены копаться в ненужных деталях реализации, то вполне можно вместо моделей создавать сервисы и модели скрывать за ними, только в этом случае следует соблюдать важное правило - контроллеры и представления должны полностью забыть о том, что в системе есть модели, и работать исключительно с сервисами, которыми эти модели обслуживаются (иначе получится абстракция с большой дырой, что неизбежно приведёт к проблемам и запутанному коду).

    • @sivr5vs38
      @sivr5vs38 5 років тому

      Nikolay Matveychuk в конце своего поста ты таки неявно продублировал автора видео. Но подожди, как работа с базой данных или файлом на диске может быть в зоне одной ответсвенности с расчетом скидки пользователя в зависимости от его дня рождения, к примеру? И кто говорил, что есть форма для реквеста? Это может быть хелзчек, который собирает данные по железу, агрегирует/мутирует/разукрашивает и записывает их в локальную базу или в стдаут в зависимости от времени суток и четности последней цифры в айпишнике хоста. Ну и этот хелзчек ещё дергается каким-нибудь кроном

    • @nikolaymatveychuk6145
      @nikolaymatveychuk6145 5 років тому

      @@sivr5vs38 в смысле неявно продублировал? я в комменте к видео явно указал, что продублировал, и даже пояснил почему (потому что писал коммент во время просмотра ставя на паузу, и предложил это решение не зная, что оно идёт далее в этом видео). "Это может быть хелзчек, который собирает данные по железу, агрегирует/мутирует/разукрашивает" - значит нужна форма (модель внешнего по отношению к системе источника данных), которая может собрать данные из этого источника. Значит она соберёт данные, провалидирует их и при запросе выдаст в удобоваримом системе формате (функции получения, валидации и передачи данных вызовет контроллер, саму логику этих функций реализует уже форма). При этом работать мы будем не с activerecord, а с чистыми моделями, потому что в данном случае получается, что данные системы находятся не в базе, а над уровнем базы, следовательно нам придётся винтить ещё и прослойку репозиториев (в которых теперь будут инкапулированы активрекорды и модели/формы для работы с другими каналами).

    • @sivr5vs38
      @sivr5vs38 5 років тому

      @@nikolaymatveychuk6145 модель для работы с моделями? Хм, а не сервис ли это получается?

  • @vbuoc
    @vbuoc 3 роки тому

    Я правильно понял. Что добавление товара в корзину лучше не делать во View приложения. А поручить это например api rest?

    • @t0digital
      @t0digital  3 роки тому

      API REST не имеет никакого отношения к теме вопроса. Во View добавления товара в корзину быть не должно, View должен вызывать функции добавления в корзину, определенные не во View.

  • @ВалерийКокорев-ч6т
    @ВалерийКокорев-ч6т 5 років тому

    Здравствуйте. Вопрос мучает меня. Пишу MVC приложение на C#. Нужно получать записи с учётом пагинации, фильтров, сортировки и всё это в разных комбинациях. Не хочется плодить кучу методов для разных вариантов выборки данных в сервисе, да и выглядит это, как задачи контроллера.
    Как правильно решать такие ситуации? Давать доступ контроллеру к орм для выборки, или добавлять методы в сервис?

    • @t0digital
      @t0digital  5 років тому

      Привет! Не надо ходить в ORM из контроллера, эту логику надо выносить в отдельный слой 100%. Как именно на уровне бизнес логики её лучше сделать вопрос второй, но все фильтрации и подобное должны быть там. Сортировка данных на мой взгляд допустима в контроллере, но фильтры в отдельном слое.

    • @ВалерийКокорев-ч6т
      @ВалерийКокорев-ч6т 5 років тому

      @@t0digital Спасибо. Было устойчивое желание опустить слой бизнес логики, а тут ваше видео.

  • @vrabosh
    @vrabosh 4 роки тому

    Когда проект небольшой, сложно читать бизнес в одном месте, а визуализацию в другом.
    Мне нравиться когда все в одном месте, но проектировка так, что это все кратко.
    Например:
    - Читаю базу корзины, и вывожу ее в нужную переменную которая потом отобразтся.
    - Удалить из корзины, удаляю и сразу отображаю..
    file #1: db.insert(...); logicKorzina; viewBar += ''
    file #2: db.del(...); logicKorzina; viewBar += ''

  • @ПолинаБескоровайная-г3т

    А что насчет DRF? В документации DRF очень много примеров того, как во views происходят прямые обращения к БД.
    Что-то типа:
    class UsersList(ListAPIView):
    queryset = User.objects.all()
    serializer_class = UsersListSerializer
    Это же нарушение MVC, нет?

    • @t0digital
      @t0digital  4 роки тому

      Drf часто провоцирует на плохой код, да

  • @SergMirny_yt
    @SergMirny_yt 4 роки тому

    Погодите. Я уточню для себя, если позволите. Модели в Джанго, да и не только в нем (например в Ларавеле тоже), по сути отвечают за коммуникацию с базой. То есть, что-то внести/извлечь в/из базы? Одновременно с этим, у разработчиков парадигмы MVC, есть пожелание, которое, по хорошему, является правилом - контроллеры должны быть худыми... И вот тут вопрос, как же писать бизнес логику? И как ее писать в модели? Если в Джанго модели содержат в себе, по сути, просто поля которые содержит база. Тут я допускаю, что я просто не образован а этом плане (по этому и спрашиваю), например как я делал в Ларавеле - создавал отдельные классы в отдельных файлах и к ним обращался из контроллеров, а в этих классах уже взаимодействовал с базой (честно, делал это посредством сырых запросов в БД, то есть, даже без моделей) и возвращал контроллеру данные для передачи во вьюху... Так как же правильно делать в джанге?

    • @t0digital
      @t0digital  4 роки тому +1

      Про Лару не скажу, с ней не работал, но в Django как такового слоя для бизнес-логики не предусмотрено в стандартных слоях. Кто-то рекомендует писать бизнес-логику в моделях, но я не считаю это правильным. Модели - описание структуры данных для БД/ORM, это не лучшее место для бизнес-логики. Я рекомендую создавать модуль services.py и писать БЛ туда, или, если БЛ много, то создавать пакет services, и делать в нём несколько модулей (файлов) с бизнес логикой.

    • @SergMirny_yt
      @SergMirny_yt 4 роки тому

      @@t0digital спасибо большое. По сути, как я понял это такой же подход как у меня в ларке был. То есть создаём отдельный файл с классами (если необходимо из несколько) и там уже занимаемся "развратом" с данными)) возвращаяя в views обработанные данные.
      Спасибо Вам большое. Вот, не примите как подхалимство, но Вы наверное один из не многих, если не единственный, настоящий практик в ютьюбе(это чувствуется), который действительно рассказывает как надо. За это Вам огромное спасибо от таких джунов как я))
      Если позволите, вот просьба как, именно, от джуна, который не имеет коммерческого опыта (хотя писал несколько приложений и web в том числе), не могли бы вы на примере какого нибудь проекта показать как это происходит в коммерческой разработке. От момента, вот приходит человек на проект, ему дают репозиторий, он его клонирует, выполняет задачу свою, коммитит на ревью, потом, сливается в общий репозиторий... Этого маслята, типа меня, как раз не знают и не понимают до конца. И это пугает )))

  • @КириллМеха
    @КириллМеха Рік тому

    Отличная лекция получилась, спасибо.

  • @АлексейТертышников-и3т

    видео классное, но, мне, как начинающему программисту, хочется своими словами описать то, что понял/ не понял из видео.
    В видео вы говорите, что бизнес-логика - это работа с корзиной: вызвать из бд по определенному запросу, и пройтись циклом, это с одной стороны. С другой стороны, насколько я понял, вы говорите, что бизнес-логика - слой servises - это чисто запросы к БД с необходимой фильтрацией.
    Относится ли к бизнес-логике: посчитать количество заказов в корзине, посчитать сумму заказа, применить какую-то скидку на каждую позицию? Или это уже относится к контроллерам (меня тоже напрягает название view).

  • @daniilafendulov7401
    @daniilafendulov7401 5 років тому

    Как раз в универе недавно проходили MVC, суть та же. Спасибо, что разобрали, так понятней стало

    • @t0digital
      @t0digital  5 років тому

      Отлично!

    • @notrlt
      @notrlt 2 роки тому +2

      У вас в универе проходят мвс? А это где?

  • @eamarc
    @eamarc 5 років тому

    Задача контроллера - превратить request в response. Все просто и понятно.

  • @qazaqbalasy916
    @qazaqbalasy916 Рік тому

    А где писать запросы в БД если не во view?

  • @Sebasq31
    @Sebasq31 3 роки тому

    Спасибо, только учусь, инфа важная)

  • @ubuntuAndrew
    @ubuntuAndrew Рік тому

    Неплохо, но упущено много важных моментов. Не всегда и не везде есть принципиальная возможность выносить всю логику за пределы view-метода. Как быть если нам нужно проверить атрибуты объекта ещё до момента инициализации сериализатора? Что если у нас имеется over-100500 полей и параметров, с которыми работает сервис? А если мы в одном запросе работаем с объектами разных типов, получится ли это сделать без затрагивания слоя представлений?

  • @DimiEG
    @DimiEG 5 років тому

    Случайно набрёл на Ваш канал. Понравились видео по Vim, так как сам являюсь его горячим поклонником после Emacs, и по tmux. Особенно как их объединить для разработки. По MVC тоже понравилось, хоть с этой темой был знаком и ранее. Про Rust ваша фраза повеселила. Сам являюсь поклонником Rust и Golang. В них как раз нет классов и классам объявлен бой. Хотелось бы послушать рассуждения на эту тему или что нибудь по языку Rust. Python недолюбливаю. Относительно минимализма и vim с Вами полностью согласен. Стараюсь IDE не использовать совсем и работать в консоли. Спасибо и удачи каналу.

    • @t0digital
      @t0digital  5 років тому

      Спасибо! Думаю, по Golang будут материалы на канале:) по Rust в ближайшее время, наверное, нет

    • @DimiEG
      @DimiEG 5 років тому

      Да, интересно посмотреть по Golang. К тому же в Vim есть плагины для работы с этим языком.
      Впечатляет как вы управляетесь с Python. Не совсем понятно как вы его используете в проектах. Это или скрипты, которые обрабатывают данные, или WEB приложения на Python?

    • @t0digital
      @t0digital  5 років тому

      Пишем и скрипты любые на питоне, в тч по обработке данных, и веб приложения

    • @t0digital
      @t0digital  5 років тому

      Golang как раз рассматриваю как замену узких мест питона

    • @DimiEG
      @DimiEG 5 років тому

      Golang для сетевых приложений очень хорош. В Python мне не нравится, что невозможно защитить код программы при передаче заказчику, что не всегда удобно или приходится шаманить с обёртками. Golang язык компилируемый. Также в Python табы управляют логикой программы. Да, код без скобок и точек с запятыми выглядит чище, но ошибки в отступе строк приводят к ошибкам в исполнении интерпретатором. С другой стороны конечно в Python очень много библиотек.

  • @andreyzavgorodniy7444
    @andreyzavgorodniy7444 5 років тому +14

    Классное видео, а где можно увидеть пример реализации слоя "services" в Django ? Или может будет такое видео?

    • @nkhitrov
      @nkhitrov 5 років тому +6

      В этом докладе вроде были примеры. Собственно, весь доклад про это
      ua-cam.com/video/yG3ZdxBb1oo/v-deo.html

    • @andreyzavgorodniy7444
      @andreyzavgorodniy7444 5 років тому

      @@nkhitrov спасибо большое)

    • @feoktant
      @feoktant 4 роки тому

      Спасибо за видео, пишу не на Питоне, но проблемы ровно те же в коде встречаю)
      Часто попадается код в CRUDах, где из контроллера вызывается Repository. По факту та же история что и с Model из View, правильно?

  • @andreypetrov5204
    @andreypetrov5204 3 роки тому

    Например, такое это бизнес логика? Такое тоже стоит выносить в отдельный слой?
    obj_list = self.model_name.objects.all().prefetch_related \
    (Prefetch('toolmove', queryset=ToolMove.objects.order_by('-date', '-id').select_related('to_supplier')))
    filtered_obj_list = ToolFilter(request.GET, obj_list)

    • @t0digital
      @t0digital  3 роки тому +1

      Получение данных с ORM - бизнес-логика. Работа с GET параметрами - не бизнес-логика. Контроллер получает данные из входных параметров HTTP запроса, возможно валидирует их (валидация может быть частью контроллера или частью бизнес-логики) и затем вызывает слой бизнес-логики, отправляя в него полученные на вход и возможно провалидированные параметры. Получает ответ от БЛ и использует его для формирования HTTP ответа.

    • @andreypetrov5204
      @andreypetrov5204 3 роки тому

      @@t0digital Спасибо. Не часто отвечают на вопросы в видео годовалой давности. В общем надо мне довольно много кода править :)

  • @sidorovich21101986
    @sidorovich21101986 5 років тому +1

    Во многих фреймворках новички пишут бизнес-логику в моделях, т. к. им кажется, что больше негде. Опытные люди обычно выносят бизнес-логику в сервисы, а в моделях остаётся только структура данных.

    • @bobobo500
      @bobobo500 5 років тому

      Это вы про микросервисную архитектуру ?!

    • @sidorovich21101986
      @sidorovich21101986 5 років тому

      @@bobobo500 Нет. Под сервисами я подразумеваю вспомогательные классы.

  • @МишаАлексеев-я1ч
    @МишаАлексеев-я1ч 4 роки тому +1

    Расскажи, пожалуйста, в отдельном видосе как ты проектируешь структуру классов, как описываешь интерфейсы и т.д.

  • @sergafanasiev7956
    @sergafanasiev7956 5 років тому

    Спасибо! Ещё раз упорядоченно об этом услышал

  • @helloworld9018
    @helloworld9018 2 роки тому

    Здравствуйте. А как, например, быть в такой ситуации: у меня есть вьюшка, в ней я переопределяю метод form_valid(), чтобы заполнить пару полей данными из бд перед сохранением, для чего пишу SomeModel.objects.get(pk=pk), присваиваю это в нужное поле и сохраняю форму. Ну да, обратился к бд из контроллера. В чём я не прав? Как бы Вы заполнили поле формы иначе?

  • @b-o-t-l-y
    @b-o-t-l-y 5 років тому

    И тут все круто! Спасибо, кодер, от Котана ))))

  • @richardclark4111
    @richardclark4111 5 років тому

    блин. Ну про Джангу прям молодец! Но есть вопрос. У Вас слой сервисов работает по принципу паттерна репозиторий? (для того, чтобы достать все заказы к примеру вы используете методы модели или так же делаете прослойку этих методов в сервисном слое?)

  • @ihorbilous7604
    @ihorbilous7604 5 років тому

    Использовать сервисы внутри джанго аппликаций - хорошая идея. Но как тогда быть например с generic views или model serializers/forms? GenericView не может существовать без relation на django model. В ModelSerializer и ModelForm тоже самое. Более того - там есть методы create, update, save -уже точно не помню как они називаются, но не суть. Если бизнес логику вынести отдельно - то вышеперечисленные инструменты не очень подойдут. Этo сильные инструменти django и если ними не пользоватся тогда зачем django нужно, если есть например Flask?

    • @t0digital
      @t0digital  5 років тому +1

      Django не лучше и не хуже Flask, они просто разные. Во Flask вы накручиваете любые нужные инструменты сами, Django даёт вам готовый неплохо собранный каркас с ORM, миграциями, надстройками для тестов, формами, отличной админкой и тд.
      Что касается бизнес-логики и джанговых/DRF методов create/read/update - они могут быть и вызывать слой бизнес-логики (сервисов)

  • @galaxycode2877
    @galaxycode2877 2 роки тому

    то есть если у меня во Views есть такой кусочек кода queryset = Book.objects.all() это не правильно?

    • @t0digital
      @t0digital  2 роки тому

      да, это не очень правильно

    • @galaxycode2877
      @galaxycode2877 2 роки тому

      @@t0digital блин! а ведь во многих видео уроках в ютубе так и учат:(

    • @t0digital
      @t0digital  2 роки тому

      для начала это ок, но для нормальной тестируемой архитектуры - нет:)

    • @galaxycode2877
      @galaxycode2877 2 роки тому

      @@t0digital а у вас есть видео-курсы или школа где можно пройти курсы?

    • @t0digital
      @t0digital  2 роки тому

      course01.to.digital/
      В мае планируется запуск второго потока. Анонс будет во всех соц сетях, в том числе на канале здесь.

  • @JustForFun_Games
    @JustForFun_Games 2 роки тому

    А разве запросы к бд не должны быть в ДАО, к которому обращается слой бизнес логики?

  • @ablyakimablyalimov8848
    @ablyakimablyalimov8848 4 роки тому

    Недавно начал смотреть Django просто для расширения кругозора.
    Было странно видеть разделение models, view, templates, кроме
    того, почему в каждом из файлов содержится сразу несколько классов, это ведь неудобно?
    Далее меня удивило то, что в моделях должна содержатся вся бизнес логика + логика работы с БД.
    По крайней мере такое впечатление складывается когда смотришь
    документацию и некоторые проекты на github.
    Со слов автора видео понял что так делают не все, что радует.
    По поводу бизнес логики, я бы вынес ее в отдельное место и назвал бы это Domain, Services как по мне это больше служебные классы.
    Для запросов в БД есть паттерн Repository, для более сложных случаев можно использовать Specification.
    Модели в данном случае оставить просто как маппинг на таблицы БД.
    К слову, например в том же Symfony PHP фреймворке все организовано куда интересней.

  • @slava_po
    @slava_po 5 років тому

    Респектую ребята!!! Отличное объяснение!

  • @АртёмК-л7д
    @АртёмК-л7д 4 роки тому +1

    В очередной раз убеждаюсь, что все эти подходы типа mvc не имеют смысла в качестве инструкций. Да, есть models.py, где лежит список сущностей и порядок работы с ними. Никто не мешает, если файл раздулся или требуется переиспользование, вынести функцию наверх файла или в отдельный файл. Точно также никто не мешает, если views.py стал нечитабельно-огромным или нужно переиспользование, вынести именно эту логику в отдельный файл и импортировать его куда надо, когда это понадобилось. Но также нет ничего плохого в том, чтобы написать логику внутри views.py. Просто естественно всегда надо думать немного наперед, разделять и переиспользовать. А когда вы по инструкции придерживаетесь всяких стандартов, то лезть за двумя строками в какие-то сервисы - ну зачем? Код - это творчество. Хорошим кодом ценители восторгаются также, как и картиной, например. В живописи тоже куча техник и подходов, весьма четко описанных, творчества там ноль. А хорошие картины ведь часто получаются на стыках этих технологий, когда худохник не тупо их использует, а знает, когда лучше так, а когда - иначе, вот и тут также.

  • @WorldCount
    @WorldCount 5 років тому

    Вот есть вопрос. Про модели в Джанго согласен полностью, как и вообще со всем видео, но... В одной книге, проверка пароля, определяется в классе модели, а вызов этого метода происходит в views.py, т.е. в модели. Выглядит вроде прилично. По опыту, можно так отступать, или лучше вывести это в отдельный класс? И про миксины хотелось бы узнать мнение. Если к примеру вывести часть бизнес-логики в миксин, не нарушит ли это MVC?

    • @t0digital
      @t0digital  5 років тому

      с миксинами надо быть аккуратненько, это множественное наследование, можно выстрелить себе в ногу случайно. Миксины должны быть очень маленькими и минималистичными, а бизнес-логика такой бывает редко

  • @AndreyChursin
    @AndreyChursin 5 років тому

    Расскажите про контроль версий для проектов (для файллв и для бд)?

    • @t0digital
      @t0digital  5 років тому

      про Git будет материал. Версионность БД в минимальном виде это механизм миграций в Django, аналогичный есть в других фреймворках

  • @gustaugutter9477
    @gustaugutter9477 5 років тому +20

    А пример джанго проекта с правильной бизнес-логикой можешь показать, а то в итоге какая-то дыра... там писать нельзя, тут тоже нельзя, зато можно вон там в уголочке, но вот как это делать не совсем понятно(совсем непонятно)

    • @WorldCount
      @WorldCount 5 років тому

      Так он же показал. Делаешь отдельный пакет и там строчишь бизнес-логику. Потом подтягиваешь её во views.

    • @gustaugutter9477
      @gustaugutter9477 5 років тому +5

      ​@@caesarfatalhammer я не говорил про бизнес. Я попросил показать практически правильное решение того, о чем он говорит. Потому что, как сказал автор, большинство пишет бизнес-логику в моделях или во вьюхах.
      Подхода, о котором он говорит, я не встречал ни в одном уроке, поэтому соответствующая просьба.
      Так что твой ядовитый высер здесь ни о чем...

    • @gustaugutter9477
      @gustaugutter9477 5 років тому +2

      @@WorldCount Ну он показал как это выглядит(как папочки лежать должны), а я прошу о тупом примере работы этих сервисов. Потому что мне непонятно зачем выводить в отдельный сервис, например, добавление товара в корзину, или оформление заказа, если мы говорим об интернет-магазине. Таким образом получится, что во вьюхе останется 2 строчки кода (вызов сервиса и return какие-то данные). Вот в этом вопрос. Зачем такое сильное дробление?
      Предполагаю, что в больших проектах оно необходимо. Я в таких не участвовал. Поэтому хочу услышать ответ от опытного человека, который занимается тем, что делится знаниями посредством своего ютуб канала. Зачем отдельный пакет с сервисами и почему это эффективнее, чем писать методы к моделям и писать БЛ во вьюхах.

    • @gustaugutter9477
      @gustaugutter9477 5 років тому +1

      @@MrBytmin Спасибо за развернутый комментарий. Действительно в видео об этом говорилось, но почему-то не уложилось по полочкам. После вашего ответа стало немного понятнее.
      Но все же посмотрев на код, было бы еще понятнее))

    • @7daysmma
      @7daysmma 5 років тому

      "правильной бизнес-логикой"
      Для меня например загадка зачем тащить MVC в Джангу. Правильным скорее будет то, что по дефолту. А по дефолту в Джанге - MVT.

  • @trtx1
    @trtx1 5 років тому +1

    Спасибо! Очень круто

  • @jshuckbot
    @jshuckbot Рік тому

    А что у вас за монитор на стене?

    • @t0digital
      @t0digital  Рік тому

      Моник LG какой-то. Он на подъёмном столе стоит

  • @Tavda
    @Tavda 5 років тому

    Я так и не научился по человечески писать код на PHP,, но мой велосипед потихоньку приходит к модели MVC :)

    • @t0digital
      @t0digital  5 років тому

      Вы на верном пути и это главное!

  • @nilsen1879
    @nilsen1879 4 роки тому

    Спасибо за видео! Хотелось бы увидеть пример, где "плохо", а где "хорошо"

    • @t0digital
      @t0digital  4 роки тому +1

      Посмотрите код ревью, несколько видео есть на канале

  • @ynxela
    @ynxela 5 років тому

    Спасибо за видео! Очень доходчиво.

  • @tigranovakyan4913
    @tigranovakyan4913 5 років тому +1

    Оставь ссылку на клавиатуру))

  • @nikitaalymov5880
    @nikitaalymov5880 4 роки тому

    Какой у вас дополнительный монитор?
    Классный канал!

    • @t0digital
      @t0digital  4 роки тому

      Спасибо! Это монитор LG 27" с type c 4к модель, не помню номер

  • @homaas7150
    @homaas7150 2 роки тому

    Не раз возвращаюсь к этому ролику) у тебя очень позитивные и полезные видео, так держать! :)
    Может подскажешь, что лучше использовать для вида приложения в веб: чистый css (scss) или bootstrap?)
    P.S. Сейчас перехожу с flask на django

    • @t0digital
      @t0digital  2 роки тому +1

      Если по-быстрому и особо не вникать, то фреймворки, а так лучше css изучить чистый, он сейчас модный и достаточно простой в использовании

  • @sergeyshevtsov5125
    @sergeyshevtsov5125 4 роки тому

    Мне понравилось решение в фреймворке fastAPI, там например вынесли бизнес-логику в отдельный модуль, в доке у них CRUD так выделили. Конечно добавляется ещё один слой, но выглядит масштабируемо и упорядоченно.
    В джанге, почему-то, в доке такого не показывают.

  • @nikzvonov2614
    @nikzvonov2614 5 років тому

    Спасибо за видео. Хотелось бы узнать, планируется ли раскрытие таких тем как Domain Driven Design, Test-Driven Development и т.п. ? Заранее спасибо за ответ.)

    • @t0digital
      @t0digital  5 років тому +1

      Да, обязательно будет

    • @nikzvonov2614
      @nikzvonov2614 5 років тому

      @@t0digital Отлично)

  • @yourownazog8069
    @yourownazog8069 Рік тому +1

    классная кружка в японском стиле =)

    • @t0digital
      @t0digital  Рік тому +1

      Спасибо:) нравится тоже:)

  • @jtprogru_channel
    @jtprogru_channel 5 років тому

    Приветствую!
    1. Огромное спасибо за контент! Всегда приятно смотреть и слушать!
    2. Можно ли получить пример по данному видео?! Хотелось бы наглядно посмотреть на организацию и логику распределения функций/классов/etc...

    • @t0digital
      @t0digital  5 років тому +1

      Это код одного из наших проектов, не могу его показать. Но сделаем какой-то живой пример может быть на стриме, на нем все будет понятно

    • @jtprogru_channel
      @jtprogru_channel 5 років тому

      Диджитализируй! АйТи студия я понял сразу какой это проект :) Поэтому и попросил что-то на коленке - петпроджект какой-то изобрести с той структурой, которую описываете.
      Собственно говоря меня именно этот момент все время тормозит в Джанго 😩

    • @t0digital
      @t0digital  5 років тому

      @@jtprogru_channel да, сделаем!

  • @ForYouNegative
    @ForYouNegative 4 роки тому

    Доступным языком, не плохо)

  • @SuperBizon012
    @SuperBizon012 5 років тому +1

    Всегда нравились аргументы типа - "Это бред, это бред"

    • @t0digital
      @t0digital  5 років тому

      Очевидно мне тоже

  • @kuziakivmarko
    @kuziakivmarko 4 роки тому

    Відео годнота!
    Спасибо
    Можете снять ролик где более подробно расскажите о создание правильной архитектуры с джанго на каких то близких к реалиям примерах?

    • @t0digital
      @t0digital  4 роки тому +1

      Спасибо! Такое видео будет

  • @ДанькаЛобанов-у6ю
    @ДанькаЛобанов-у6ю 5 років тому +1

    Сделай пожалуйста видос про выбор лицензии проекта при создании репозитори на гитхабе. в чём между ними различия и какую для какого проекта лучше выбрать.

  • @ОлегВоронов-э2ц
    @ОлегВоронов-э2ц 5 років тому

    Огромное спасибо. Я уже успел задуматься, почему view, когда там обрабатываются запросы. Твоё решение кажется супер крутым, спасибо. Конкретно в моем случае, очень поможет. Не мог бы ты или другие люди в коментах ответить на мои вопросы?
    Я реализую приложение для документооборота.
    1) Имеется несколько должностей работников, для каждой описал отдельный модуль.
    Поскольку у работника может быть несколько ставок, сделал такую связь: User -> Worker -> WorkerPosition

    • @t0digital
      @t0digital  5 років тому

      Не смог понять структуру классов/таблиц и что за данные в них по описанию - надо вникать более глубоко, чтобы ответить на вопросы

  • @ibarya
    @ibarya 5 років тому

    Можешь пожалуйста снять видео о клавиатурах какими пользуешься)

    • @t0digital
      @t0digital  5 років тому

      Макбучной родной и Leopold fc660m PD, когда есть время что-то написать сосредоточиться

    • @ibarya
      @ibarya 5 років тому

      @@t0digital да я знаю, просто хочется посмотреть о леопольде)

  • @ВладиславОрлов-ф4ц
    @ВладиславОрлов-ф4ц 5 років тому

    Cпасибо за объяснения MVC. Изучал Django по книжке Дронова и очень сильно раньше бесился, почему автор упорно называет вьюхи контроллерами. Теперь понимаю, откуда растут ноги. Интересно было бы узнать, чем руководствовались создатели Джанги, когда вводили такую архитектуру и нейминг.

    • @t0digital
      @t0digital  5 років тому

      Да, мне тоже интересно, почему так

    • @Орест-к9к
      @Орест-к9к 3 роки тому

      @@t0digital может потому что Django реализует не MVC а MVT архитектуру?)

    • @t0digital
      @t0digital  3 роки тому

      @@Орест-к9к не суть вообще

  • @alexanderbardin8272
    @alexanderbardin8272 5 років тому

    Сколько не читал/смотрел/изучал примеры 99% пихают логику в Views, что-то мелкое в методы класса модели, называя это вычисляемыми полями (если вывод информации), или в метод save если требуется что-то сделать с инстансом, но никто не выносит в отдельные "файлы". При этом в работе столкнулся с тем, что если "засунуть" все во View то начинается боль в определенном месте, и в итоге пришел к такому выводу:
    - сложная логика, т.е. логика затрагивающая N моделей и/или требующая расчета/анализа, т.е. действий над данными - отдельные модули с классами для работы с нужными моделями (проверки, логика, сохранение, обновление)
    Т.е. по сути тут даже логически придешь к выводу, что нужно вынести это куда-то иначе твоя вьюха или модель станет просто не читаемым куском г..на
    Пихать же все в модель верх безумства, на примере своей работы уже задумываюсь даже вычисляемые поля выносить с моделей, ибо 20 полей модели + 20 вычисляемых, которые частично могут затрагивать другие модели это печаль и простыня, а если туда еще запихнуть логику - тушите свет.

    • @t0digital
      @t0digital  5 років тому

      Спасибо, что поделились! Всё именно так и есть

  • @nikolaisalikov1257
    @nikolaisalikov1257 5 років тому +1

    Forms & Signals, не? Хотя, можно и отдельный сервисный слой.

    • @t0digital
      @t0digital  5 років тому

      Сигналы это вообще ОЧЕНЬ спорное решение в джанго, дебажить это потом боль. У форм область применимости небольшая.

  • @vitalibirulia
    @vitalibirulia 4 роки тому +3

    Django как и DRF и генерируемая адмика Django, прямо кричит, что все процессы должны происходить вокруг модели данных.
    Т.е структура models должна повторять то, что после будет выводиться в templates или пересылаться по api. Т.е Data driven design. На этом и построена вся Django. Мы создаем модели, чтобы они более-менее накладывались на реляционную модель. С помощью ModelForm мы валидируем сохраняем данные в эту модель. Выдергиваем во view использую GenericViewSet, где с минимальными усилиями это дело достаем из базы и выводим. Из-за того, что у нас все крутится вокруг models, мы получаем генерируемую админку. Все drf это только подтверждает. Он жестко завязан на работу с моделями.
    Здесь нет места какой-то бизнес логике. Логики, как таковой, здесь вообще должно быть минимум. Мы просто отображаем данные из базы, вставляя на свои места в шаблоне или выводим в json. Поэтому и логику пишут ближе к выводу или данным.
    Ок, давайте вынесем бизнес логику в отдельное место. Что получаем, директорию с файлами, которая набита кучей жестко связанного кода, сильно завязанного на orm, модели, формы и т.п django. По сути всю логику сгребаем в кучу. Хорошо ли это, да нет, это ужасно!
    Почему-то многие думают, что если закинуть весь код в директорию services, то сразу будет хорошо. Нет, не будет.
    Если начать думать о архитектуре, то станет ясно, что нужно отделить всю логику от django. От джанго останется только orm, models, views и все. Забудьте про админку, forms и все такое.
    Views только работает как controller, orm вовсе изолируем за интерфейсом. Никакого Product.objects.all() из бизнес логики. Все обращение с бизнес логикой строим по средствам DTO и вызовов методов интерфейса persistent. Внутри бизнес логики уже строим нужное Entity, Services, Use Cases и т.п.
    Но на это не пойдут большинство тех, кто пишет с исп. этого фреймворка, т.к оставь в нем только orm и views, станет ясно, что и сама django уже не особо то и нужна, можно Flask и Sqlalchemy или т.п, все тоже будет.
    Я считаю, что нет большого смысла как-то сильно внедрять в Django какую-то выраженную архитектуру, вроде DDD или разновидность Чистой архитектуры или даже EDD, SOA и т.п.
    У Django своя хорошая ниша, не сложные проекты, который строятся вокруг БД. На ней очень удобно такое реализовывать. Там все для этого. Хотя лет 5 назад, я бы с пеной у рта доказывал обратное.)))
    Те, кто в силах построить сложный проект, у кого есть обширные знания архитектур их особенностей и опыт ведение я внедрения, вряд ли выберут Django. Это не его ниша.
    Для сложных проектов, с большим набором логики и т.п, скорее всего будет исп. другой стек, C#, Java и т.п. Языки с которые предоставляют строгость в исп. подходах. Нормальные абстрактные классы, интерфейсы, проверка типов. То, где можно в полной мере исп. все принципы SOLID и т.п. Это дает больше гарантий, что проект будет поддерживаемый.
    Тут стоит заметит, что я не говорю, что Python не подходит для больших проектов, подходит, но только как какая-то их часть, какой-то отдельный сервис, то, в чем Python действительно хорош. Но будет ли в этом отдельном сервисе Django, скорее всего нет.

  • @MrDnovik
    @MrDnovik 5 років тому

    Спасибо, очень полезно!

  • @andreyosokin1218
    @andreyosokin1218 5 років тому

    а для Джанго нет интеграции ?

    • @t0digital
      @t0digital  5 років тому

      Интеграции чего?

    • @andreyosokin1218
      @andreyosokin1218 5 років тому

      @@t0digital salesbeat, не заметил сначала раздела с документацией)))

    • @t0digital
      @t0digital  5 років тому

      Да, наши виджеты и апи можно интегрануть куда угодно, в тч в джанговый магазин

    • @andreyosokin1218
      @andreyosokin1218 5 років тому

      @@t0digital а вобще спасибо за ваш контент, очень доходчиво и не по самым верхам, как многие делают! Много у вас подчерпнул из роликов

    • @t0digital
      @t0digital  5 років тому

      @@andreyosokin1218 спасибо, рад, что находите полезным! Приятно