DZone
Thanks for visiting DZone today,
Edit Profile
  • Manage Email Subscriptions
  • How to Post to DZone
  • Article Submission Guidelines
Sign Out View Profile
  • Post an Article
  • Manage My Drafts
Over 2 million developers have joined DZone.
Log In / Join
Please enter at least three characters to search
Refcards Trend Reports
Events Video Library
Refcards
Trend Reports

Events

View Events Video Library

Zones

Culture and Methodologies Agile Career Development Methodologies Team Management
Data Engineering AI/ML Big Data Data Databases IoT
Software Design and Architecture Cloud Architecture Containers Integration Microservices Performance Security
Coding Frameworks Java JavaScript Languages Tools
Testing, Deployment, and Maintenance Deployment DevOps and CI/CD Maintenance Monitoring and Observability Testing, Tools, and Frameworks
Culture and Methodologies
Agile Career Development Methodologies Team Management
Data Engineering
AI/ML Big Data Data Databases IoT
Software Design and Architecture
Cloud Architecture Containers Integration Microservices Performance Security
Coding
Frameworks Java JavaScript Languages Tools
Testing, Deployment, and Maintenance
Deployment DevOps and CI/CD Maintenance Monitoring and Observability Testing, Tools, and Frameworks

Because the DevOps movement has redefined engineering responsibilities, SREs now have to become stewards of observability strategy.

Apache Cassandra combines the benefits of major NoSQL databases to support data management needs not covered by traditional RDBMS vendors.

The software you build is only as secure as the code that powers it. Learn how malicious code creeps into your software supply chain.

Generative AI has transformed nearly every industry. How can you leverage GenAI to improve your productivity and efficiency?

Related

  • Alexa Skill With Local DynamoDB
  • An Introduction to Type Safety in JavaScript With Prisma
  • How Continuous Integration Can Help You to Make a Simple Deploy in Salesforce
  • How GitHub Codespaces Helps in Reducing Development Setup Time

Trending

  • Understanding the Shift: Why Companies Are Migrating From MongoDB to Aerospike Database?
  • Modern Test Automation With AI (LLM) and Playwright MCP
  • The Perfection Trap: Rethinking Parkinson's Law for Modern Engineering Teams
  • Advancing Robot Vision and Control
  1. DZone
  2. Coding
  3. Tools
  4. Turn Visual Studio Code Into A Top-Notch JavaScript IDE With These 25 Extensions

Turn Visual Studio Code Into A Top-Notch JavaScript IDE With These 25 Extensions

You can make VS Code much more powerful in minutes. This blog post shows how Visual Studio Code extensions can help you enhance the IDE experience for JavaScript.

By 
Lars Grammel user avatar
Lars Grammel
·
Jan. 14, 22 · Tutorial
Likes (4)
Comment
Save
Tweet
Share
8.1K Views

Join the DZone community and get the full member experience.

Join For Free

Visual Studio Code is a great code editor that comes with JavaScript and TypeScript features like basic refactoring out of the box. However, its true strength is an outstanding extension marketplace. There are extensions for almost anything you might want to do in an IDE (Integrated Development Environment), and they can make VS Code many times better.

Unfortunately, it can be time-consuming to find the right extensions and configure VS Code. Many developers prefer the out-of-the-box experience that IDEs such as Webstorm provide. This blog post shows how Visual Studio Code extensions can help you enhance the IDE experience for JavaScript. It covers:

  • Code Completion and Snippets
  • Linting, Spell Checking, and Hints
  • Formatting, Code Actions, and Refactoring
  • Editor Support for Additional File Types
  • Organizing Comments, TODOs, and Bookmarks
  • Testing
  • Debugging
  • Version Control
  • Database, REST API, and Docker Clients

You can conveniently install the 25 extensions that convert Visual Studio Code into a full-blown JavaScript IDE with the JavaScript IDE Extension Pack. Icon or color themes and keyboard shortcut maps are not covered here, nor are they included in the extension pack because they depend much more on personal preferences than most extensions.

Let's go into the different features and see what's possible in VS Code with just a few extensions:

Code Completion and Snippets

Code completion (IntelliSense) features can make writing code faster and easier. Visual Studio Code provides IntelliSense for JavaScript and TypeScript by default and contains powerful Emmet support for expanding snippets.

One of the latest trends in code completion is AI assistants. However, my experience with AI code completion assistants such as GitHub Copilot and Tabnine was mixed so far, and therefore I've not included them in the extension pack, but they might work great for you.

Here are a few snippet extensions that can boost your productivity:

ES7 React/Redux/GraphQL/React-Native Snippets

The ES7 snippets extension provides many expandable everyday snippets. For example, defining imports and exports, creating methods and loops, and returning Promises. The extension also contains many snippets for React and GraphQL.

Emmet Live

With the Emmet Live extension, you can preview your Emmet output while crafting the Emmet abbreviation. You can start it with the Emmet Live command.

Vscode-Random

When writing tests or creating mockups, it often takes time to come up with good fake data. You can use the vscode-random extension to generate many kinds of random data, such as numbers, locations, emails, IPs, names, and DateTime values.

Linting, Spell Checking, and Hints

The best time to get feedback on your code is while editing, i.e., when you can quickly change the code and learn as you go. By integrating linting, spell checking, and other suggestions into your editing process, you avoid some of the more extended pre-commit checks and pull request round trips.

Code Spell Checker

It is easy for typo and small spelling errors to slip into variable and function names, strings, comments, etc. The Code Spell Checker extension highlights those mistakes and can often provide the correct spelling as a fix.

ESLint

ESLint is the most commonly used JavaScript linter. It helps you "find and fix problems in your JavaScript code." ESLint is very extensible and configurable, and many teams have their own custom rules for their projects. The ESLint extension shows errors and warnings directly in your editor and lets you quick-fix them easily. You can also configure it to auto-fix any problems on save.

Error Lens

The Error Lens extension highlights and displays errors, warnings, and information messages directly in the editor. With it, you don't need to take the extra step of finding out what the squiggly underlines mean - it is right in front of you. If the information gets overwhelming, you can easily toggle it on and off for different message types with the Error Lens: Toggle... commands.

Formatting, Code Actions, and Refactoring

Visual Studio Code comes with basic refactorings and quick fixes such as Rename, Extract Method and Extract Variable. The editing experience can be further enhanced with extensions:

Prettier

Formatting code manually is very time-consuming and error-prone. With Prettier, the de-facto standard code formatter of the JavaScript world, you can format your code automatically. You can even configure the Prettier VS Code extension to format the source code when you save it.

Change Case

The Change Case extension adds a wide range of commands to change the case of the selected text, e.g., into camel case, snake case, Pascal case, etc. The commands all have the Change Case prefix.

P42 JavaScript Assistant

The JavaScript Assistant that I've developed adds 60+ refactorings, quick fixes, and code actions to VS Code. It contains React refactorings, ECMAScript modernizations, syntax and language element conversions, actions for logical expressions and control flow, and code cleanups.

Editor Support for Additional File Types

When you work with JavaScript and TypeScript, there are many other relevant file types. Visual Studio Code already has editing support for JSON, HTML, CSS, and Markdown. The following extensions add more enhanced editor support:

npm

The npm extension validates the installed Node.js modules defined in package.json files.

SVG Preview

The SVG Preview extension does exactly that: show a preview for .svg files. You can pan and zoom the image in the preview, and it updates automatically when you edit the SVG source.

Even Better TOML

TOML is a configuration file format that aims to be simple and easily readable. The Even Better TOML extension adds full editor support, including syntax highlighting, folding, navigation, and formatting.

Organizing Comments, TODOs, and Bookmarks

In larger development projects that last many years and involve many developers, staying organized around comments and TODO items becomes increasingly essential. The following extensions can help with that:

Better Comments

The Better Comments extension shows different kinds of comments in different colors. It supports prefixes like !, ?, and TODO.

Todo Tree

TODOs and FIXMEs easily get forgotten about and lost. The Todo Tree extension scans the files in your workspace for TODO and FIXME annotations and organizes them in a sidebar view. You can easily browse them by folder and revisit essential items that come to your attention.

Bookmarks

With the Bookmarks extension, you can save and label important source code locations and organize them in a sidebar panel. This can be helpful when you are exploring a complex codebase or when you have locations that you return to frequently.

Testing

Writing and running tests is a crucial development activity. In particular, unit tests that run in the IDE are helpful to get immediate feedback. The following extensions add test runner support to VS Code:

Test Explorer

The Test Explorer is a set of extensions that integrate testing seamlessly into VS Code. Its Test Explorer UI extension adds a side panel for running the tests and seeing the results, and the Test Explorer Status Bar adds the number of tests to the status bar.

The UI components show the information produced by test adapters. Which adapter you need for testing depends on your testing frameworks. For JavaScript, testing adapter extensions for the following test frameworks are available:

  • Mocha (included in extension pack)
  • Jest (included in extension pack)
  • Jasmine
  • Angular/Karma
  • AVA
  • TestyTs
  • React-scripts

Visual Studio Code has added native testing capabilities in version 1.59. You can enable them in the Test Explorer by setting testExplorer.useNativeTesting to true in the VS Code settings.

Debugging

Visual Studio Code comes with an excellent JavaScript debugger out of the box. It can connect to Node.js, Edge, and Chrome, so in most cases, there is no need for extra extensions when it comes to JavaScript debugging.

Version Control

Git is the most used version control system (VCS), and there are great extensions for VS Code. You can also find extensions for other VCS's such as Subversion on the VS Code marketplace.

GitLens

The GitLens extension adds several panels to the source control sidebar and enhances the editor with information overlays. The sidebar panels help you manage branches, stashes, commits, file history, remotes, and the editor extensions include a blame view, change indications, an authorship code lens, and more. GitLens is an essential extension that makes working with Git in VS Code much easier.

Git Graph

The Git Graph extension shows the Git history visually in an editor panel. You can open it with the "View Git Graph" command. In the graph view, you can explore individual commits and perform many everyday Git operations. For example, you can check out branches and commits, create branches, cherry-pick commits, perform merges, etc.

Database, REST API, and Docker Clients

Developing full-stack JavaScript often means working with external systems such as databases, REST APIs and Docker. The following extensions add clients to VS Code:

Database Client

The Database Client extension lets you connect to MySQL/MariaDB, PostgreSQL, SQLite, Redis, and ElasticSearch. You can explore databases in its sidebar panel, open database tables as editor panels, and run custom SQL queries. The database table content is editable. Any changes that you make are immediately stored in the database.

Thunder Client

The Thunder Client extension integrates a client for REST APIs into VS Code. It is a lightweight alternative to Postman. You can send any kind of http(s) request, see the response data and organize your requests in collections.

Docker

Working with containers has become an essential part of day-to-day development for many software engineers. With the Docker extension, you can explore your running Docker containers, get editor support for Docker files, and more.

Bonus

Here is a small bonus extension that I find very useful:

CodeSnap

You can take beautiful screenshots of your code in no time with the CodeSnap extension. Start with the CodeSnap command, select the code you want to screenshot and click the lense button.

Conclusion

I hope the post gave you a few ideas for extensions that can improve your VS Code experience. With the JavaScript IDE Extension Pack, you can install them all and then disable or uninstall the ones that don't fit your needs.

Visual Studio Code code style Integrated development environment JavaScript unit test Git Database Virtual screening Docker (software)

Published at DZone with permission of Lars Grammel. See the original article here.

Opinions expressed by DZone contributors are their own.

Related

  • Alexa Skill With Local DynamoDB
  • An Introduction to Type Safety in JavaScript With Prisma
  • How Continuous Integration Can Help You to Make a Simple Deploy in Salesforce
  • How GitHub Codespaces Helps in Reducing Development Setup Time

Partner Resources

×

Comments
Oops! Something Went Wrong

The likes didn't load as expected. Please refresh the page and try again.

ABOUT US

  • About DZone
  • Support and feedback
  • Community research
  • Sitemap

ADVERTISE

  • Advertise with DZone

CONTRIBUTE ON DZONE

  • Article Submission Guidelines
  • Become a Contributor
  • Core Program
  • Visit the Writers' Zone

LEGAL

  • Terms of Service
  • Privacy Policy

CONTACT US

  • 3343 Perimeter Hill Drive
  • Suite 100
  • Nashville, TN 37211
  • support@dzone.com

Let's be friends:

Likes
There are no likes...yet! 👀
Be the first to like this post!
It looks like you're not logged in.
Sign in to see who liked this post!