You must log in or # to comment.
async function createUser(user) { validateUserInput(user) || throwError(err.userValidationFailed); isPasswordValid(user.password) || throwError(err.invalidPassword); !(await userService.getUserByEmail(user.email)) || throwError(err.userExists); user.password = await hashPassword(user.password); return userService.create(user); }Or
async function createUser(user) { return await (new UserService(user)) .validate() .create(); } // elsewhere… const UserService = class { #user; constructor(user) { this.user = user; } async validate() { InputValidator.valid(this.user); PasswordValidator.valid(this.user.password); !(await UserUniqueValidator.valid(this.user.email); return this; } async create() { this.user.password = await hashPassword(this.user.password); return userService.create(this.user); } }I would argue that the validate routines be their own classes; ie
UserInputValidator,UserPasswordValidator, etc. They should conform to a common interface with avalid()method that throws when invalid. (I’m on mobile and typed enough already).“Self-documenting” does not mean “write less code”. In fact, it means the opposite; it means be more verbose. The trick is to find that happy balance where you write just enough code to make it clear what’s going on (that does not mean you write long identifier names (e.g.,
getUserByEmail(email)vs.getUser(email)or betterfetchUser(email)).Be consistent:
get*andset*should be reserved for working on an instance of an objectis*orhas*for Boolean returns- Methods/functions are verbs because they are actionable; e.g.,
fetchUser(),validate(),create() - Do not repeat identifiers: e.g.,
UserService.createUser() - Properties/variables are not verbs; they are state: e.g.,
validvsisValid - Especially for JavaScript, everything is
constunless you absolutely have to reassign its direct value; I.e., objects and arrays should beconstunless you use the assignment operator after initialization - All class methods should be private until it’s needed to be public. It’s easier to make an API public, but near impossible to make it private without compromising backward compatibility.
- Don’t be afraid to use
if {}statements. Short-circuiting is cutesy and all, but it makes code more complex to read. - Delineate unrelated code with new lines. What I mean is that jamming all your code together into one block makes it difficult to follow (like run-on sentences or massive walls of text). Use new lines and/or
{}to create small groups of related code. You’re not penalized for the white space because it gets compiled away anyway.
There is so much more, but this should be a good primer.



