Clean Code has so far been all about writing good lines and blocks of Code. It delves into the proper composition of functions and how they relate to each other. But for all the talk about the expressive power of code statements and the functions they constitute, we can’t get clean code unless we focus on higher levels of code organization.
10.1 Class organization
According to standard Java conventions, a class should start with a list of variables. If there are public static constants, they should come first. Private static variables are followed by private entity variables, followed by public functions after the list of variables. This follows the top-down principle and makes the program read like a newspaper article.
But JavaScript uses stereotype inheritance: each object inherits properties and methods from the stereotype object. Prototype inheritance can simulate classical class inheritance. In order to bring traditional classes to JavaScript, ES2015 introduced the class syntax, which is still prototype-based at the bottom, just the syntactic sugar of archetypal inheritance.
Class 10.2 should be short
The first rule about classes is that they should be short. Rule number two is shorter.
The name of the class should describe the responsibility for clearing it. In fact, naming is officially the first way to help determine the length of a class. If you can’t give a class an exact name, the class is probably too long. The more ambiguous the class name, the more likely it is to have too many responsibilities. Then the class would not qualify as short.
10.2.1 Principle of single rights and responsibilities
The single accountability principle (SRP) states that a class or module should have one and only one reason for modification. This principle provides both a definition of rights and responsibilities and guidelines for the length of classes. A class should have only one responsibility — only one instance of modification.
The system should consist of many short classes rather than a few large ones. Each subclass encapsulates a responsibility, only a reason for modification, and collaborates with a few other classes to achieve the desired system behavior.
10.2.2 cohesion
Classes should have only a few variables. Each method in a class should operate on one or more of these variables. In general, the more variables a method operates on, the more it sticks to the class. If every variable in a class is used by every method, the class has greater cohesion.
10.3 Organization for modification
In addition to the single accountability principle (SRP), other key principles of object-oriented design, such as the development-closure principle (OCP) : classes should be open to extension and closed to modification, are equally important.
We want to make the system a shelf that causes as little trouble as possible when adding or modifying features. In an ideal system, we would add new features by extending the system rather than modifying existing code.