IntelliSense
IntelliSense is a general term for various code editing features including: code completion, parameter info, quick info, and member lists. IntelliSense features are sometimes called by other names such as "code completion", "content assist", and "code hinting."
IntelliSense for your programming language
Visual Studio Code IntelliSense is provided for JavaScript, TypeScript, JSON, HTML, CSS, SCSS, and Less out of the box. VS Code supports word-based completions for any programming language but can also be configured to have richer IntelliSense by installing a language extension.
Below are the most popular language extensions in the Visual Studio Marketplace. Select an extension tile below to read the description and reviews to decide which extension is best for you.
IntelliSense features
VS Code IntelliSense features are powered by a language service. A language service provides intelligent code completions based on language semantics and an analysis of your source code. If a language service knows possible completions, the IntelliSense suggestions will pop up as you type. If you continue typing characters, the list of members (variables, methods, and more) is filtered to only include members containing your typed characters. Pressing Tab or Enter will insert the selected member.
You can trigger IntelliSense in any editor window by typing ⌃Space (Windows, Linux Ctrl+Space) or by typing a trigger character (such as the dot character (.) in JavaScript).
The suggestions control supports CamelCase filtering, which means that you can type the letters that are upper cased in a method name to limit the suggestions. For example, "cra" brings up "createApplication".
If you prefer, you can turn off IntelliSense while you type. See Customizing IntelliSense, to learn how to disable or customize VS Code's IntelliSense features.
As provided by the language service, you can see quick info for each method by either pressing ⌃Space (Windows, Linux Ctrl+Space) or selecting the > icon. The accompanying documentation for the method expands to the side. The expanded documentation remains available and updates as you navigate the list. You can close this by pressing ⌃Space (Windows, Linux Ctrl+Space) again or by selecting the close icon.
After choosing a method, you are provided with parameter info.

When applicable, a language service surfaces the underlying types in the quick info and method signatures. In the previous screenshot, you can see several any types. Because JavaScript is dynamic and doesn't need or enforce types, any suggests that the variable can be of any type.
Types of completions
The JavaScript code in the following screenshot illustrates IntelliSense completions. IntelliSense gives both inferred proposals and the global identifiers of the project. The inferred symbols are presented first, followed by the global identifiers (indicated by the abc word icon).

VS Code IntelliSense offers different types of completions, including language server suggestions, snippets, and simple word-based textual completions.
| Icon | Name | Symbol type | 
|---|---|---|
| Methods and Functions | method,function,constructor | |
| Variables | variable | |
| Fields | field | |
| Type parameters | typeParameter | |
| Constants | constant | |
| Classes | class | |
| Interfaces | interface | |
| Structures | struct | |
| Events | event | |
| Operators | operator | |
| Modules | module | |
| Properties and Attributes | property | |
| Enumerations | enum | |
| Enumeration members | enumMember | |
| References | reference | |
| Keywords | keyword | |
| Files | file | |
| Folders | folder | |
| Colors | color | |
| Unit | unit | |
| Snippet prefixes | snippet | |
| Words | text | 
Customizing IntelliSense
You can customize your IntelliSense experience in settings and keyboard shortcuts.
Settings
The settings shown below are the default settings. You can change these settings in the Settings editor (⌘, (Windows, Linux Ctrl+,)).
{
    // Controls if quick suggestions should show up while typing
    "editor.quickSuggestions": {
        "other": true,
        "comments": false,
        "strings": false
    },
     // Controls whether suggestions should be accepted on commit characters. For example, in JavaScript, the semi-colon (`;`) can be a commit character that accepts a suggestion and types that character.
    "editor.acceptSuggestionOnCommitCharacter": true,
    // Controls if suggestions should be accepted on 'Enter' - in addition to 'Tab'. Helps to avoid ambiguity between inserting new lines or accepting suggestions. The value 'smart' means only accept a suggestion with Enter when it makes a textual change
    "editor.acceptSuggestionOnEnter": "on",
    // Controls the delay in ms after which quick suggestions will show up.
    "editor.quickSuggestionsDelay": 10,
    // Controls if suggestions should automatically show up when typing trigger characters
    "editor.suggestOnTriggerCharacters": true,
    // Controls if pressing tab inserts the best suggestion and if tab cycles through other suggestions
    "editor.tabCompletion": "off",
    // Controls whether sorting favours words that appear close to the cursor
    "editor.suggest.localityBonus": true,
    // Controls how suggestions are pre-selected when showing the suggest list
    "editor.suggestSelection": "first",
    // Enable word based suggestions
    "editor.wordBasedSuggestions": "matchingDocuments",
    // Enable parameter hints
    "editor.parameterHints.enabled": true,
}
Tab completion
The editor supports tab completion, which inserts the best matching completion when pressing Tab. This works regardless of the suggest control showing or not. Also, pressing Tab after inserting a suggestion inserts the next best suggestion.
By default, tab completion is disabled. Use the editor.tabCompletion setting to enable it. These values exist:
- off- (default) Tab completion is disabled.
- on- Tab completion is enabled for all suggestions and repeated invocations insert the next best suggestion.
- onlySnippets- Tab completion only inserts static snippets which prefix match the current line prefix.
Locality bonus
Sorting of suggestions depends on extension information and on how well they match the current word you are typing. In addition, you can ask the editor to boost suggestions that appear closer to the cursor position, using the editor.suggest.localityBonus setting.

In the previous screenshot, you can see that count, context, and colocated are sorted based on the scopes in which they appear (loop, function, file).
Suggestion selection
By default, VS Code pre-selects the first suggestion in the suggestion list. If you'd like different behavior, for example, to always select the most recently used item in the suggestion list, you can use the editor.suggestSelection setting.
The available editor.suggestSelection values are:
- first- (default) Always select the top list item.
- recentlyUsed- The previously used item is selected unless a prefix (type to select) selects a different item.
- recentlyUsedByPrefix- Select items based on previous prefixes that have completed those suggestions.
Selecting the most recently used item is very useful as you can quickly insert the same completion multiple times.
"Type to select" means that the current prefix (roughly the text left of the cursor) is used to filter and sort suggestions. When this happens and when its result differs from the result of recentlyUsed, it will be given precedence.
When using the last option, recentlyUsedByPrefix, VS Code remembers which item was selected for a specific prefix (partial text). For example, if you typed co and then selected console, the next time you typed co, the suggestion console would be pre-selected. This lets you quickly map various prefixes to different suggestions, for example co -> console and con -> const.
Snippets in suggestions
By default, VS Code shows snippets and completion proposals in one control. You can modify the behavior with the editor.snippetSuggestions setting. To remove snippets from the suggestions control, set the value to "none". If you'd like to see snippets, you can specify the order relative to suggestions; at the top ("top"), at the bottom ("bottom"), or inline ordered alphabetically ("inline"). The default is "inline".
Keyboard shortcuts
The keyboard shortcuts shown here are the default keyboard shortcuts. To assign a different keyboard shortcut, use the Keyboard Shortcuts editor (⌘K ⌘S (Windows, Linux Ctrl+K Ctrl+S)).
| Command | Keybinding | 
|---|---|
| editor.action.triggerSuggest | ⌃Space (Windows, Linux Ctrl+Space) | 
| toggleSuggestionDetails | ⌃Space (Windows, Linux Ctrl+Space) | 
| toggleSuggestionFocus | ⌃⌥Space (Windows, Linux Ctrl+Alt+Space) | 
There are many more keyboard shortcuts related to IntelliSense. Open the Default Keyboard Shortcuts (File > Preferences > Keyboard Shortcuts) and search for "suggest".
Enhance completions with AI
GitHub Copilot provides coding suggestions as you type in your editor. You can also ask Copilot coding-related questions, such as how best to code something, how to fix a bug, or how someone else's code works.
To get started:
- 
Install the GitHub Copilot extension. 
- 
Discover the key functionality with our Copilot quickstart. 
If you don't have a Copilot subscription yet, you can use Copilot for free by signing up for the Copilot Free plan and get a monthly limit of completions and chat interactions.
Troubleshooting
If you find IntelliSense has stopped working, the language service may not be running. Try restarting VS Code and this should solve the issue. If you are still missing IntelliSense features after installing a language extension, open an issue in the repository of the language extension.
For configuring and troubleshooting JavaScript IntelliSense, see the JavaScript documentation.
A particular language extension may not support all the VS Code IntelliSense features. Review the extension's README to find out what is supported. If you think there are issues with a language extension, you can usually find the issue repository for an extension through the VS Code Marketplace. Navigate to the extension's Details page and select the Support link.
Next steps
IntelliSense is just one of VS Code's powerful features. Read on to learn more:
- Debugging - Learn how to set up debugging for your application.
- Creating Language extensions - Learn how to create extensions that add IntelliSense for new programming languages.
- GitHub Copilot in VS Code - Learn how to use AI with GitHub Copilot to enhance your coding.
Common questions
Why am I not getting any suggestions?
This can be caused by a variety of reasons. First, try restarting VS Code. If the problem persists, consult the language extension's documentation. For JavaScript-specific troubleshooting, please see the JavaScript language topic.
Why am I not seeing method and variable suggestions?

This issue is caused by missing type declaration (typings) files in JavaScript. Most common JavaScript libraries ship with declaration files or have type declaration files available.
Make sure to install the corresponding npm or yarn package for the library you are using. Learn more about IntelliSense in the Working with JavaScript article. For other languages, please consult the extension's documentation.