5 принципов читаемого кода: KISS, YAGNI, DRY, BDUF и Бритва Оккама
Описываем 5 принципов, которые позволят сделать ваш код чистым и читабельным: KISS, YAGNI, DRY, BDUF и Бритва Оккама.
11К открытий13К показов
Данная статья предназначена для понимания основных принципов написания читаемого кода. Для некоторых принципов будут приведены примеры React и JavaScript.
Влад Матковский
TeamLead Web Frontend
Во многих проектах идет слепое следование SOLID принципам (которые являются не менее важными!), при этом нарушаются и не берутся во внимание многие другие стандарты написания кода. Не нужно впадать в крайности — необходимо соблюдать баланс. Итак, к основным принципам разработки и написания чистого когда относятся:
KISS — Always Keep It Simple, Stupid (будь проще)
- Ваши методы должны быть небольшими (40-50 строк).
- Каждый метод решает одну проблему.
- При модификации кода в будущем не должно возникнуть трудностей.
- Система работает лучше всего, если она не усложняется без надобности.
- Не устанавливайте целую библиотеку ради одной функции из неё.
- Не делай того, что не просят.
- Писать код необходимо надежно и «дубово».
Как это можно реализовать в React? С приходом хуков основной единицей построения веб-приложения становится функциональный компонент. Например, можно создавать компоненты небольшого размера. Логику необходимо выносить во вспомогательные функции. Если это работа с использованием состояния — создавать кастомные хуки. В итоге получаем компонент небольшого размера (функция), вспомогательные функции малого размера, пользовательские хуки (так же являются функциями). Вся логика вынесена в небольшие функции, которые в дальнейшем будет удобно покрыть unit тестами.
В целом, для упрощения и сокращения кода, необходимо использовать стрелочные функции, значения для параметров функции по умолчанию, деструктуризацию, async/await синтаксис, обязательно использование блоков try/catch для надежности. Взгляните, как усложнен код ниже:
Как выглядит это проще при использовании стрелочных функции и параметров по умолчанию:
В целом, это касается не только кода. При создании архитектуры проекта, структуры директорий не изобретайте очередной велосипед. Уделите хотя бы 5 минут и поищите примеры решения, спросите у коллег, почитайте про минусы и плюсы данного подхода и выбирайте наиболее подходящий. Ниже пример очередного идеального «своего решения ? «.
YAGNI — You are not gonna need it (Вам это не понадобится)
- Реализуйте только то, что нужно здесь и сейчас, а не в теории, что оно пригодится в будущем.
- Подчищайте ненужный код (найдите через Git историю при надобности).
- Программист не должен добавлять новый функционал, о котором его не просят (благими намерениями без должной проверки вы только добавите багов).
DRY — Don’t Repeat Yourself (Не повторяйся)
- Избегайте копирования кода.
- Выносите общую логику.
- Прежде чем добавлять функционал, проверьте в проекте, может, он уже создан.
- Константы.
В React этот принцип можно выразить через переиспользуемые компоненты. В целом, на этом и базируется принцип React. UI необходимо создавать из переиспользуемых блоков.
Создайте кнопку или поле ввода и подключайте их, где и сколько раз необходимо. В плане логики здесь конечно также на помощь приходят вспомогательные функции (утилиты или хелперы) и хуки. В примере ниже api запрос, взаимодействие с селектом, полем ввода вынесенно в отдельные хуки, которые можно в дальнейшем переиспользовать.
В целом код должен пройти через следующие стадии:
Дополнительно можно придерживаться правил, представленных ниже.
Бритва Оккама
- Не нужно создавать лишние сущности без необходимости в них.
- Всегда начинайте с максимально простого кода, затем увеличивайте сложность по мере необходимости.
BDUF — Big Design Up Front (Сначала большое проектирование)
- Прежде чем переходить к реализации, убедитесь, что все продумано.
- Разработчик должен сначала завершить проектирование. После этого проект можно реализовать.
- Разделите требования на несколько этапов, определите приоритеты, начинайте с этапа с наивысшим приоритетом.
- Обсудите архитектуру проекта с командой и другими людьми, которые участвуют в проекте до старта.
Итак, выше были перечислены основные принципы написания хорошего кода. При этом важно помнить, что для каждой задачи эти принципы применяют по мере необходимости, а не для того, чтобы просто применить.
Придерживайтесь их, и в будущем вам благодарны будете и вы сами, и ваши коллеги.
11К открытий13К показов