Can I read a sample for free?
Of course! Many chapters are available to read online.
Iterating over collections and why traditional loops, such as for
or while
, may not be the best approach
Writing good conditions and simplifying the code by removing unnecessary ones
Improving code readability by making it easier to understand what variables are doing and how they are used in the code
Why mutation is hindering code readability and what can we do about it
Writing useful comments, when to write them and when not
How clear names make it easier to understand the code, and how to improve naming in our code
Divide and conquer, or merge and relax
Splitting code into functions and modules, when is the right time to introduce an abstraction, and when it’s better to wait
Don’t make me think
All the different ways programmers like to write clever code, and why we should avoid clever code as much as possible
Code style
Which code styles are actually improving readability and which are just opinions that don’t matter much
Lint your code
How linters can help us maintain consistent and modern codebase, and promote some of the techniques discussed in the previous chapters
Autoformat your code
How tools can make our lives much easier by formatting code for us
Learn your code editor
Different techniques for editing code and customizing our environment to make our work more efficient and less tiring
Other techniques
Make impossible states impossible
Don’t try to predict the future
Become a code scout
Write testable code
Write greppable code
Avoid not invented here syndrome
Avoid cargo cult programming
Debug code with emojis
Go for a walk or talk to a rubber duck
Here’s a list of all the techniques and patterns described in the book.
2-minute rule
Algorithm deduplication
A/HC/LC pattern
Arrange-Act-Assert
Array method chaining
Campsite rule
Colocation
Comments with examples
Condition expansion
Data normalization
defaultProps
for testing React components
Dependency injection
Discriminated unions
Early returns, or guard clauses
Enums
Explicit mutation
Finite-state machines
Greppable code
Hack comments
Hiding complexity
Implicit assertions
Inline refactoring
Iteration using array methods
Keep it simple, stupid (KISS)
Named function parameters
Optional function parameters
Parallel coding
Range conditions
Readable numbers
Reducing variables’ lifespan
Rubberducking
Sections, paragraphs, phrases
Separation of “what” and “how”
Separation of code that changes often
Single responsibility principle
Tables and maps
Todo comments
Write everything twice, or we enjoy typing (WET)
You aren’t gonna need it (Yagni)
Here’s a list of all the code smells and antipatterns described in the book.
100% code coverage
Abbreviations and acronyms
Array.reduce()
method
Barrel files
Broken windows theory
Cargo cult programming
Default exports
Function parameters mutation
Don’t repeat yourself (DRY)
Monster utility files
Negative booleans
Nested ternaries
Not invented here syndrome (NIH)
Magic numbers
Mutating array methods
Pascal-style variables
Premature abstraction, or premature generalization, or speculative generality
Reusing variables
Shortcuts
Single return law
I’ve been following the author’s blog for quite some time to grab an advice or to catch up on best engineering practices. I was excited to find out there’s a whole dedicated book he was working on 🙌 I’m into several chapters now and already got enlightened on some topics I thought I knew well 🙂 I really like a mix of theory and clear practical examples that are up to a point. It’s never a dry reading so can highly recommend it 👍
Artem skillfully highlights common code smells and anti-patterns that I also frequently encounter when reviewing code. Each chapter offers actionable insights on refactoring and improving code readability, which are critical whether you’re just starting out or are a longtime developer looking to polish your skills. I already “felt” the lessons but hadn't really internalized them. Reading them from someone else sort of fixed them in my understanding of code and how to work with it.
Of course! Many chapters are available to read online.
Almost! I’m planning to finish the book by the end of summer 2024.
Yes, I’m planning to keep the book as a living snapshot of my programming knowledge, and also update the example with the latest JavaScript features. Subscribe to my newsletter to know about major updates.
Not necessarily, though it will certainly help. However, even if you’re working with other languages, you could still find the book useful.
Not yet, but I’m planning to publish the book on Amazon as soon I finish writing the book.
Not yet, but I’m planning to publish the dead tree version as soon I finish writing the book.
Yes, LeanPub has 60-day money back.
Yes, write me at artem@sapegin.ru.
Write me at artem@sapegin.ru, and we’ll think of something.
Hola! I’m Artem.
I’m a software engineer with 20 years of experience in small startups and large corporations, like Wayfair, Mail.ru, Here Technologies, Omio, Stage+, and Badoo. I created React Styleguidist (a tool to create React components and share them with your team), among many other open source projects.
I’ve been blogging about frontend development for almost as many years. My favorite topics are component-driven development, testing, and accessibility.
Drop me a line at artem@sapegin.ru, @sapegin@mastodon.cloud, @iamsapegin, or open an issue.