Cross-browser issues are a major problem for front-end developers, especially due to Internet Explorer and Safari. It is a good practice to test our code against all the browsers supported once the development is finished and (possibly) test it with different devices. In this last case, the Chrome browser is helpful in testing different mobile renderings and engines.
Some parts of a project will never be easy to scan and understand. Consider a complicated regular expression, or a math function calculating angles or switching between degrees and radians. Without the comment above, beginner and intermediate readers will be fairly clueless to the scripts' meaning.
Well commented code is extremely important. Take time to describe components, how they work, their limitations, and the way they are constructed. Don't leave others in the team guessing as to the purpose of uncommon or non-obvious code.
- Each SCSS partial should have a clear comment header to define the role of this section of code.
- Place comments on a new line above their subject.
- Keep line-length to a sensible maximum (e.g. 80 columns).
- Make liberal use of comments to break SCSS code into discrete sections.
- Use "sentence case" comments and consistent text indentation.
- Keep One space between the single line comment and the comment you are writing.
/**
* Multi line comment in JavaScript.
* This is a multi line comment with the text that describes, in detail, how the
* below code works, any limitations, and the way it is constructed.
* This comment is a standard in the JavaScript/TypeScript world.
*/
// Single line comment in JavaScript
/***********************************************************************************\
* Multi line comment in the style files (CSS/SCSS). *
* There is no real standard for multi-line comments in the styling files, you can *
* find many inspirations outside or simply use this example. *
\***********************************************************************************/
/* Single line comment in the style files (CSS/SCSS) */
This is another good example of a comment that describes the reason for some rules in the ruleset:
/**
* Grid container
*
* Must only contain `.cell` children.
*
* 1. Remove inter-cell whitespace
* 2. Prevent inline-block cells wrapping
*/
.grid {
font-size: 0; /* 1 */
height: 100%;
white-space: nowrap; /* 2 */
}