WEB-Программист
Переключить навигацию

Язык

  • Русский
  • Русский
Связаться с нами

Поиск

  • Книги
  • JavaScript
  • HTML и CSS
  • Другие
  • SEO
  • wordpress
  • Дизайн
  • Laravel
  • Phyton
  • React js
  • Android
  • SQL и языки запросов
  • Yii
  • Шрифты
  • Статьи
  • Laravel
  • wordpress
  • Темы Wordpress
  • Интернет магазин
  • JavaScript
  • © 2015-2026 Andrii Beznosko

  • Hosting CityHost

DDD Ultra-Light

  • Описания
  • Описание/Скачать

Laravel 4.2

Некоторые люди говорят, что DDD сложно, затратно и должно использоваться с осторожностью. Некоторые команды практикуют «DDD Life» — они используют паттерны проектирования приложений, описанные Эриком Эвансом в большой синей книге, но игнорируют идеи, которые считаются на самом деле важными.

По правде говоря, я никогда не работал над проектом с использованием «настоящего DDD» (пока что!). Тем не менее, DDD вдохновило меня и я верю, что оно сделало меня более профессиональным разработчиком. Я использую маленькие кусочки и части DDD, большинство из которых нельзя назвать «настоящим DDD», но я точно помню, откуда приходит вдохновение.

Я считаю, что истинная ценность труда Эванса в том, что практически каждый может использовать некоторые идеи, которые он предложил. Они не требуют каких либо специальных инструментов, денег, согласования или реорганизации. Это те простые идеи, которые вы можете начать воплощать в жизнь уже с понедельника (или завтра). Я называю эти идеи «DDD Ultra-Lite». Некоторые из них не новы, но я верю, что Эванс проделал хорошую работу для описания DDD понятными словами и метафорами во избежание моментов непонимания.

Итак, вот эти идеи (в случайном порядке):

1. Прислушивайтесь к тому, что говорит бизнес

Я не шучу. Этот совет, вероятно, такой же старый, как и программирование само по себе, но Эванс описывает эту идею достаточно интересно.

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

Иногда бывает и наоборот. Вы наконец находите хорошую модель и при общении с бизнесом на вас смотрят, как на тупейшего человека в мире. «Да, вы правы, это очевидно, но почему у вас заняло так много времени понимание этих концепций?». Это означает, что вы наконец на верном пути.

2. Проектируйте ровно столько, сколько нужно, не больше и не меньше

Избыток и недостаток проектирования — это проблемы. Найти баланс между глубоким проектированием и только «исполнением функций для достижения цели» — это нетривиальная задача. Эванс даёт нам несколько советов, которые я нахожу очень полезными:

  • Используйте простейшую модель, которая решает текущую проблему. Не пытайтесь спроектировать реальность, вы не сможете.
  • Помните о чистоте кода. Ваш код и архитектура должна легко изменяться в будущем. Если ваш проект успешен, тогда вы будете менять архитектуру множество раз. Вы не сможете спроектировать идеал с первого раза (и, наверное, никто не сможет).
  • Если код начинает «уходить» от вас и вы видите, что вносить изменения становится всё сложнее, это знак о том, что проблема в текущей модели. Время рефакторинга этой части программы.
  • Рефакторьте маленькие части системы по мере необходимости, снова проектируя простейшую модель, которая решает новую проблему.
  • Обсуждайте. За чашкой кофе с разработчиками и архитекторами. Обсуждайте вашу проблему с ними, проводите мозговой штурм, выспитесь и возвращайтесь ещё.
  • Не обсуждайте больше, чем нужно. Эванс предполагает множественные итерации, короткие дискуссии(1-1.5 часа), обучение и общение.

3. Задавайте сложные вопросы

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

Другими словами, вместо добавления ещё нескольких if-ов или дополнительных классов, возможно, стоит пересмотреть архитектуру и найти что-либо более подходящее или принципиально другое.

4. Не изобретайте колесо.

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

Что самое интересное, мне приходилось множество раз упускать этот подход. Многие люди ищут решения в интернете — в различных блогах, смотрят презентации. И почти никогда я не слышу, чтобы кто-либо сказал:«Я читал об этом в книге XYZ». Обычно сессии «проектирования», которые я посещал, являлись обычным мозговым штурмом. И потом, спустя месяцы, я мог наткнуться на случайную презентацию, которая показывала другой подход к решению нашей проблемы, значительно более предпочтительный.

Многие люди на конференциях пытаются найти решения в других областях знаний. Они пытаются найти решения общих проблем и адаптировать их под свои специфические нужды. Но, тем не менее, в «реальной жизни» очень часто наш кругозор не слишком велик и мы не можем позволить себе большое исследование.

Улучшение, которое я сделал лично для себя в области «исследования проблемы» — использовать более организованные источники и просматривать классические источники. Блоги и презентации очень ценны, но, не поймите меня не правильно, книги лучше организованы и содержат более проверенную временем информацию. Тем не менее, никто не оспаривает «великолепные» статьи в обычном случайном поиске гугла. Если они написаны экспертами, то это должно подходить в большинстве случаев. Но даже эксперты не всегда объясняют свои решения и подробно описывают проблему.

Если я вспоминаю что-либо, что может быть полезным, я возвращаюсь к источнику этой информации для освежения памяти. Я пытаюсь найти связанные статьи, книги или презентации. Если я понятия не имею, с чего начинать, есть несколько идей, которые для меня полезны: возвращение к теории, просмотр каталогов (по паттернам или проектированию), фокусирование на контексте и описании проблемы, поиск хороших практик от IT профессионалов в конкретной области.

Заключение

Всё это достаточно тривиально, но я советую вам попробовать применять всё это так, «как вы это понимаете». Вы будете удивлены.

Комментарии
Всего комментариев: 0
Оставить комментарий Отменить ответ

Ваш email не будет опубликован.

Жанр: Главная » Статьи » Laravel » DDD Ultra-Light
Статус: Для продвинутых программистов
Ссылка на оригинал статьи (Если указана или эта статья не авторская) Скачать
На сайт предоставил Сен 18, 2015 13:05 Andriy

Статьи опубликованные на сайте WEB-Программист указаны со ссылками на источник. Администрация сайта не несет ответственность за их использование Вами

Laravel
Previous Next

Смотри также:

Способы организации пространств имён классов в Laravel

В коде: <?php namespace App; class SendReceipt {}   Структура папок: src Receipt ReceiptRepository SendReceipt SendReceiptHandler User UserRepository CreateUser CreateUserHandler   Преимущества: Проще не иметь дело с подпространствами имён. В очень маленьких приложениях это может быть нормально. Если у вас...

Расширяем классы Laravel методом `orAbort` при помощи трейта

Вдохновлённый статьёй Edd Man's об опциональных управляющих потоках, я создал небольшой пакет Laravel для реализации опциональной остановки приложения. Он предоставляет трейт Spatie\OrAbort\OrAbort, который может использоваться с любым классом. Всем методам класса добавляется orAbort функциональность. Когда оригинальный метод возвращает false, будет...

Трюки Eloquent для лучших репозиториев (Laravel)

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

Генерируем ЧПУ в Laravel 5

Обычно в ЧПУ страниц используется транслит, перевод или фраза в оригинальном состоянии без изменений. С третьим вариантом проблем возникать не должно, Laravel понимает кириллицу из коробки. Рассмотрим остальные два варианта. Перевод Для генерации переведённого ЧПУ нам понадобится пакет Google Translate...

Интеграционное тестирование в Laravel 5.1: Фабрики моделей

При тестировании кода часто приходится создавать тестовые записи одной или нескольких моделей. Вы могли использовать нечто такое: $post = new Post; $post->title = 'Fake Blog Post Title'; $post->body = 'Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nullam lorem erat,...

Связаться с нами

- Премиум темы и плагины WP Star бесплатно -

We use cookies on our website to give you the most relevant experience by remembering your preferences and repeat visits. By clicking “Accept”, you consent to the use of ALL the cookies.
Cookie settingsACCEPT
Manage consent

Privacy Overview

This website uses cookies to improve your experience while you navigate through the website. Out of these, the cookies that are categorized as necessary are stored on your browser as they are essential for the working of basic functionalities of the website. We also use third-party cookies that help us analyze and understand how you use this website. These cookies will be stored in your browser only with your consent. You also have the option to opt-out of these cookies. But opting out of some of these cookies may affect your browsing experience.
Necessary
Always Enabled
Necessary cookies are absolutely essential for the website to function properly. These cookies ensure basic functionalities and security features of the website, anonymously.
CookieDurationDescription
cookielawinfo-checbox-analytics11 monthsThis cookie is set by GDPR Cookie Consent plugin. The cookie is used to store the user consent for the cookies in the category "Analytics".
cookielawinfo-checbox-functional11 monthsThe cookie is set by GDPR cookie consent to record the user consent for the cookies in the category "Functional".
cookielawinfo-checbox-others11 monthsThis cookie is set by GDPR Cookie Consent plugin. The cookie is used to store the user consent for the cookies in the category "Other.
cookielawinfo-checkbox-necessary11 monthsThis cookie is set by GDPR Cookie Consent plugin. The cookies is used to store the user consent for the cookies in the category "Necessary".
cookielawinfo-checkbox-performance11 monthsThis cookie is set by GDPR Cookie Consent plugin. The cookie is used to store the user consent for the cookies in the category "Performance".
viewed_cookie_policy11 monthsThe cookie is set by the GDPR Cookie Consent plugin and is used to store whether or not user has consented to the use of cookies. It does not store any personal data.
Functional
Functional cookies help to perform certain functionalities like sharing the content of the website on social media platforms, collect feedbacks, and other third-party features.
Performance
Performance cookies are used to understand and analyze the key performance indexes of the website which helps in delivering a better user experience for the visitors.
Analytics
Analytical cookies are used to understand how visitors interact with the website. These cookies help provide information on metrics the number of visitors, bounce rate, traffic source, etc.
Advertisement
Advertisement cookies are used to provide visitors with relevant ads and marketing campaigns. These cookies track visitors across websites and collect information to provide customized ads.
Others
Other uncategorized cookies are those that are being analyzed and have not been classified into a category as yet.
SAVE & ACCEPT