Navigation and Search in JavaScript
warning
Starting from ReSharper 2022.2, active development of productivity features for JavaScript, TypeScript, JSON, CSS, and Protobuf is suspended, and these features are disabled by default. To enable them, select the corresponding checkboxes on the Environment | Products & Features page of ReSharper options Alt+R, O: JavaScript and TypeScript, CSS Language, and Protobuf.
Most of ReSharper's navigation and search features are also supported in JavaScript. You can find the detailed information on these features in the corresponding topics of the Navigate and search section. In the main topic of the section, you can also find the feature matrix and check what exactly is supported in JavaScript.
In this topic, you can find some examples of using navigation and search features in JavaScript.
Navigation commands are available:
in the ReSharper | Navigate menu
in the context menu in the editor
on the Navigate To context menu
You can also:
navigate from the File Structure window
find usages of a symbol
File Structure helps overview the structure of the current file. ReSharper detects code constructs common for all programming languages as well as some specific constructs for JavaScript, for example, modules. All module members are visible within module only, so the corresponding icon is displayed for each member.
data:image/s3,"s3://crabby-images/5f7f9/5f7f9cd28fc51d683b20ea423f034627756a2c58" alt="ReSharper: File Structure for JavaScript files ReSharper: File Structure for JavaScript files"
To display anonymous and therefore unnamed functions in the File Structure window, ReSharper retrieves their names from their declarations.
data:image/s3,"s3://crabby-images/0a7a2/0a7a2c51e1dd653bd63b7f6d4a55d27da2b59e5b" alt="ReSharper: File Structure for JavaScript files ReSharper: File Structure for JavaScript files"
ReSharper takes into account XML documentation comments and extracts useful information. If data types of parameters are not specified explicitly within function signature, you can still see them in the File Structure window because they are specified within XML documentation.
data:image/s3,"s3://crabby-images/ee62b/ee62bd92931c2ce9a911850d0071b62b00ab4f96" alt="ReSharper: File Structure for JavaScript files ReSharper: File Structure for JavaScript files"
Also, you can navigate to a member declaration by double-clicking the member in the File Structure window.
Go to Declaration - place the caret at the name of a function and navigate directly to the file where the function is declared.
data:image/s3,"s3://crabby-images/01668/01668533ac5d88fa750657853f76bb1c4bf6e7ad" alt="ReSharper: Go to Declaration in JavaScript ReSharper: Go to Declaration in JavaScript"
If the selected item has several declarations, you are prompted to choose one from the list.
Pay attention that functions declared within paired <script>
tags are visible in the current file only.
Go to Usages of Symbol - very useful if you want to find out how many usages of a function are in the whole solution.
data:image/s3,"s3://crabby-images/dba11/dba118db2c4e7355748ea5406710739cbf302092" alt="ReSharper: Go to Usage in JavaScript ReSharper: Go to Usage in JavaScript"
If you place the caret a symbol within paired <script>
tag and invoke the command, ReSharper will look through the current file only.
Go to File Member - helps you quickly navigate to a desired member within the current file.
data:image/s3,"s3://crabby-images/aa4e8/aa4e8a4949b8f5ff9d0f50b5db92ddb995ee6f11" alt="ReSharper: Go to File Member in JavaScript ReSharper: Go to File Member in JavaScript"
To find your way around without scanning thousands lines of code, use ReSharper search features. As usual, you can define certain search target and vary its search scope via Find Usages and Find Usages Advanced features.
Place the caret at the name of a variable or a function.
Do one of the following:
From the main menu, choose ReSharper | Find | Find Usages.
Click Find Usages in the context menu.
Press ShiftF12.
If only one usage is found, ReSharper navigates to the usage directly in the editor.
If several usages are found, the Find Results window opens.
In the screenshot below, you see the differences between Find Usages and Find Usages Advanced.
data:image/s3,"s3://crabby-images/4b27a/4b27a89aa5a3b2da74756b69a3a47b07947db141" alt="ReSharper: Find Usages in JavaScript ReSharper: Find Usages in JavaScript"
To navigate to a usage in source code from the Find Results window, select and double-click the usage.
If you want to see all usages of a symbol in the current file, press ShiftAltF11 and highlight usages within this file.
data:image/s3,"s3://crabby-images/097b3/097b3f5216f5684805207d018c8c365b8c91f2f8" alt="ReSharper: Highlight Usages in JavaScript ReSharper: Highlight Usages in JavaScript"
Sometimes standard search facilities cannot help, especially when you are looking for syntax constructs which are similar but not identical. In such cases the Structural Search and Replace feature could be helpful. To use this feature and bear fruits, make three steps: create placeholders, write a pattern and invoke the search process.
Let's find try catch
statements with empty catch
blocks. The following pattern can be used for this purpose:
data:image/s3,"s3://crabby-images/5e928/5e928b0474f772e9e47de9801acd223615c2f1d8" alt="ReSharper: Structural Search and Replace in JavaScript ReSharper: Structural Search and Replace in JavaScript"
In addition to standard JavaScript language syntax you see placeholders enclosed in $
dollar signs. These placeholders are displayed to the right of the pattern. As we are looking for empty catch blocks, the most important condition here is the empty braces in the catch
statement. As soon as all conditions are defined, click Find to start the search process.
All results are displayed in the Find Results window. As you can see at the preview, ReSharper has found only those try catch
statements that have empty catch
blocks.
data:image/s3,"s3://crabby-images/f7d6f/f7d6fafbcda4e6601f513282384f9b6019e5bd48" alt="ReSharper: Structural Search and Replace in JavaScript ReSharper: Structural Search and Replace in JavaScript"
You can create patterns right from source code. Select a desired code block, right-click the selection and choose Search with Pattern in the context menu.