DEV Community

Cover image for Using JSDoc to write better JavaScript Code
Ingo Steinke, web developer
Ingo Steinke, web developer

Posted on • Updated on

Using JSDoc to write better JavaScript Code

Using TypeScript consistently offers a lot of benefits, especially for writing clean code to prevent unnecessary bugs and errors. But it takes some time and effort to learn, and you have to adapt every code snippet after copy-pasting from a tutorial or a StackOverflow example. Quite a challenge when re-using code for React, Node, Express and Mongoose like I did in my full-stack web app side project.

Alternatives to TypeScript

  • Popular, but unhelpful, alternative: don't care at all.

  • Use eslint, but that's not an alternative. With or without strong typing, you should lint your code anyway to benefit from (mostly) helpful hints and warnings.

  • ReactPropTypes add some type checking to ECMAScript / JavaScript in React applications, but PropTypes are merely footnotes, placed far away from where they would be most useful, while still bloating your code.

PropTypes example with an unhappy emoji and critical handwritten notes reading: merely a footnote below?

And there are no PropTypes in Vanilla JS.

  • enter JSDoc:

JSDoc

Often overlooked, maybe never even heard of until now, JSDoc deserves more attention, as it brings a lot of advantages out of some short lines of documentation.

Code Documentation

That's JSDoc's original purpose: generating a code / API documentation out of a few lines placed before variables, functions, and classes.

Similar approaches have been used with Java and PHP for a long time, and JSDoc follows established practice and is quite easy to learn.

Hints and Code Completion

Using JSDoc inside a modern IDE, you'll get another benefit: live code inspection, warnings, and proper code completion even for the most obscure DOM methods you never knew about before. Or well-known classics like event.currentTarget that still have some tricky pitfalls.

Here is a - seemingly simple - example:

Screenshot of annotated code with method hints in PhpStorm IDE

I wanted to allow a modal dialog to be closed typing the Escape key. My first quick code-like-it's-1999-style script (not shown here) was frowned upon by eslint. ☹️

Writing Clean, Modern Vanilla JS Code

So I decided to write proper, modern code, but still plain "Vanilla JS" (that does not need a transpiler to produce working code, unlike TypeScript, which does not have native browser support, not even in Microsoft's Edge browser).

I wrote a function that takes two arguments: an event, and an optional DOM element so that we are able to close a specific modal dialog from outside without relying on the event context.

Adding a JSDoc comment before, it becomes

/**
 * close an open modal dialog
 * @param {MouseEvent} event
 * @param {HTMLElement=} elementToClose
 */
const modalClose = function modalClose(event, elementToClose) {
  // ...
};
Enter fullscreen mode Exit fullscreen mode

telling my readers (of this code, and of a possible, automatically generated, documentation / API reference) what the function is supposed to do, and what arguments it expects:

@param {MouseEvent} event

Now my IDE (PhpStorm) will show me helpful information:

Screenshot of the annotated MouseEvent

I don't even have to look up the proper type string to write in the JSDoc comment!

When I start typing, PhpStorm has some suggestions for code completion even in this special kind of comment, suggesting MouseEvent on top of the list.

Screenshot showing a dropdown with suggested type annotations

JSDoc Syntax

The basic syntax is rather simple.

Annotations blocks are special comments that start with a slash and a double asterisk /**

A parameter hint starts with an at sign, the word "param", and a type definition inside curly braces, followed by the parameter's name.

To mark an optional parameter, add an equals sign behind the type, like

@param {HTMLElement=} elementToClose
Enter fullscreen mode Exit fullscreen mode

but to be more clear to human readers, we can also add anything behind the parameter's name, like

@param {HTMLElement=} elementToClose (optional) DOM element to receive .closed CSS class
Enter fullscreen mode Exit fullscreen mode

Now my editor shows me type annotations, that are not part of my written code (unlike they would be in TypeScript) but rather implicitly follow from my code. So my actual code stays short and compact, while the implicit meaning is still more obvious than before.

Assistance for Lazy Developers

Not only do we see the additional hint event: MouseEvent, but when we start using the event in our code below, there are more code suggestions, helping us to choose methods and properties that are actually available and not deprecated.

Image showing code completion suggestions for 'event.' in PhpStorm

More assistance as we continue: hints and documentation everywhere. We don't even have to visit MDN in our browser anymore!

Screenshot showing documentation for event.currentTarget.closest

Conclusion

JSDoc makes coding in JavaScript easier, helping us to code quickly while avoiding obvious errors, just by adding some lines of optional comments in our code.

Top comments (3)

Collapse
 
oncode profile image
Manuel Sommerhalder

You get the type safety and autocompletion without using another language or changing the build pipeline with JSDocs. I really don't understand the hype for Typescript.

Collapse
 
peerreynders profile image
peerreynders

There is no type safety with plain JSDoc. It's

"An API documentation generator for JavaScript."

that some editors understand well enough to support code completion (which probably is the greatest factor of the "TypeScript in VS Code" popularity).

Preact's code base is written in JavaScript but it also provides TypeScript types in declaration files (e.g. internal.d.ts) which are then referenced in the JavaScript implementation files via JSDoc (e.g. create-element.js).

This means that the JavaScript doesn't have to be transpiled but can be type-checked (type-linted?) on demand with the TypeScript tooling.

The downside is that you have to be pretty good with TypeScript types to author the declaration files; meanwhile most developers aren't willing to leave the comfort of plain "TypeScript in VS Code" behind once they've grown accustomed to it.

Collapse
 
oowombatoo profile image
Vic Webster

Totally agree. TypeScript is okay. It's a tool, it has it's purposes. It's not an "improvement" or "fix" for JavaScript. Only people who have never bothered to learn JavaScript think like that.