All of these are independent. variations can yield optimizations of course.
- Formatter - format code you write acc to a style guide. Comsetic.
- Linter - static check code, better idioms, highligh security issues.
neither intend to change code. Just displace and refactor.
- Bundler - combine all JS files to generate a single one, essentially. Traditonal browser requirement. Does optimizations like tree shaking (dead code removal). Realistically, takes care of non-JS assets and linkages too.
- Transpiler - combine modern/fancy JS into lowest-denominator-compatible JS. Originally meant for IE and old browsers when ES6 came about. JSX to JS also happens in this step, if needed.
- Minification - decrease bundle size by removing whitespace, changing variable names. Optionally, leaves some cryptic tokens in output and generates a "source map". When a capable runtime is presented with both the minified file and source map, it can point out corresponding parts, with step-through precision. very useful for debugging.
- Formatter - Prettier is opinionated (low config)
- Form factor: works as an editor plugin. Has an independent CLI too
- Easy to use, no setup.
- Can auto-format files.
- Linter - eslint. Can lint static files only (deliberate).
- Form factor: CLI tool, pass files to lint.
- Simple usage is easy.
- Highly configurable. But doesn't need much config due to existence of good presets. A good preset + some exceptions if needed go a long way.
- Normal usage generally requires an observer-presenter layer, i.e. a "project files changed" observer generates a stream and passes it to eslint, which returns the results back, which get presented in the terminal, browser console or mobile device - whatever you're developing. Example of observer-presenter layers: nodemon, create-react-app dev server, vscode ESLint plugin.
- Can auto-fix files in many scenarios.
- Bundler - webpack.
- Form factor - CLI tool.
- Easy to use in the simple scenario.
- Highly configurable and configuration is needed for medium to complex projects
- React Native - metro for RN, no config needed. Not many customization options.
- Transpiler - babel
- Form factor - CLI tool. Input file to output file.
- Args: Can specify target JS spec. Inputs non-exact enums. or exact specs, whatever you like.
- Handles JSX to JS too. And many other source, target combinations
- Minification - uglifjs
- Form factor: simple CLI, input file to output file.
- Has option to generate corresponding source map(s).
- Gotcha: package name is hyphenated "uglify-js", but the CLI command has no hyphens
uglifyjs
Frontend projects usually need all steps.
Backend projects can afford to be skip transpilation and other steps, since Node.js usually supports JS flavors. Bundling may still be useful here.