StyleGuide
An unofficial TypeScript StyleGuide
People have asked me for my opinions on this. Personally I don't enforce these a lot on my teams and projects but it does help to have these mentioned as a tie breaker when someone feels the need to have such strong consistency. There are other things that I feel much more strongly about and those are covered in the tips chapter (e.g. type assertion is bad, property setters are bad) 🌹.
Key Sections:
Variable and Function
Use
camelCase
for variable and function names
Reason: Conventional JavaScript
Bad
Good
Class
Use
PascalCase
for class names.
Reason: This is actually fairly conventional in standard JavaScript.
Bad
Good
Use
camelCase
of class members and methods
Reason: Naturally follows from variable and function naming convention.
Bad
Good
Interface
Use
PascalCase
for name.
Reason: Similar to class
Use
camelCase
for members.
Reason: Similar to class
Don't prefix with
I
Reason: Unconventional.
lib.d.ts
defines important interfaces without anI
(e.g. Window, Document etc).
Bad
Good
Type
Use
PascalCase
for name.
Reason: Similar to class
Use
camelCase
for members.
Reason: Similar to class
Namespace
Use
PascalCase
for names
Reason: Convention followed by the TypeScript team. Namespaces are effectively just a class with static members. Class names are
PascalCase
=> Namespace names arePascalCase
Bad
Good
Enum
Use
PascalCase
for enum names
Reason: Similar to Class. Is a Type.
Bad
Good
Use
PascalCase
for enum member
Reason: Convention followed by TypeScript team i.e. the language creators e.g
SyntaxKind.StringLiteral
. Also helps with translation (code generation) of other languages into TypeScript.
Bad
Good
Null vs. Undefined
Prefer not to use either for explicit unavailability
Reason: these values are commonly used to keep a consistent structure between values. In TypeScript you use types to denote the structure
Bad
Good
Use
undefined
in general (do consider returning an object like{valid:boolean,value?:Foo}
instead)
Bad
Good
Use
null
where its a part of the API or conventional
Reason: It is conventional in Node.js e.g.
error
isnull
for NodeBack style callbacks.
Bad
Good
Use truthy check for objects being
null
orundefined
Bad
Good
Use
== undefined
/!= undefined
(not===
/!==
) to check fornull
/undefined
on primitives as it works for bothnull
/undefined
but not other falsy values (like''
,0
,false
) e.g.
Bad
Good
Formatting
The TypeScript compiler ships with a very nice formatting language service. Whatever output it gives by default is good enough to reduce the cognitive overload on the team.
Use tsfmt
to automatically format your code on the command line. Also your IDE (atom/vscode/vs/sublime) already has formatting support built-in.
Examples:
Quotes
Prefer single quotes (
'
) unless escaping.
Reason: More JavaScript teams do this (e.g. airbnb, standard, npm, node, google/angular, facebook/react). Its easier to type (no shift needed on most keyboards). Prettier team recommends single quotes as well
Double quotes are not without merit: Allows easier copy paste of objects into JSON. Allows people to use other languages to work without changing their quote character. Allows you to use apostrophes e.g.
He's not going.
. But I'd rather not deviate from where the JS Community is fairly decided.
When you can't use double quotes, try using back ticks (`).
Reason: These generally represent the intent of complex enough strings.
Spaces
Use
2
spaces. Not tabs.
Reason: More JavaScript teams do this (e.g. airbnb, idiomatic, standard, npm, node, google/angular, facebook/react). The TypeScript/VSCode teams use 4 spaces but are definitely the exception in the ecosystem.
Semicolons
Use semicolons.
Reasons: Explicit semicolons helps language formatting tools give consistent results. Missing ASI (automatic semicolon insertion) can trip new devs e.g.
foo() \n (function(){})
will be a single statement (not two). Recommended by TC39 as well.
Array
Annotate arrays as
foos:Foo[]
instead offoos:Array<Foo>
.
Reasons: Its easier to read. Its used by the TypeScript team. Makes easier to know something is an array as the mind is trained to detect
[]
.
Filename
Name files with camelCase
. E.g. accordian.tsx
, myControl.tsx
, utils.ts
, map.ts
etc.
Reason: Conventional across many JS teams.
type vs. interface
Use
type
when you might need a union or intersection:
Use
interface
when you wantextends
orimplements
e.g
Otherwise use whatever makes you happy that day.
Last updated