This refactoring allows you to create a new field based on a selected expression, initialize it with the expression or from the constructor, and replace occurrences of the expression in the current type with references to the newly introduced field.
In the example below, we use this refactoring to replace two occurrences of the same string with a new constant field:
|Before refactoring||After refactoring|
To introduce a field
- Select an expression in the editor.
Do one of the following:
- Press Ctrl+Alt+D.
- Press Ctrl+Shift+R and then choose Introduce Field
- Right-click and choose Refactor | Introduce Field on the context menu.
- Choose in the main menu.
- If more than one occurrence of the selected expression is found, ReSharper displays the drop-down menu where you can choose whether to apply the refactoring to all occurrences or only to the current one.
dialog box opens.
Specify the name for the new field and choose the access modifier.
Optionally, specify whether to add
readonlymodifiers to the filed.
Choose how to initialize the filed:
- Current member: initializes the field in the current member (this option is only available if you chose to replace a single occurrence or if all occurrences are within the current member).
- Field initializer: initializes the field in the declaration.
- Constructor(s): initializes the field in the constructor or constructors of the containing class; if there are no constructors, a parameterless constructor is created to initialize the field.
- Introduce constant: creates a constant field. This option is only available if the value of the selected expression corresponds to a built-in type.
- To apply the refactoring, click Next.
- If no conflicts are found, ReSharper performs the refactoring immediately. Otherwise, it prompts you to resolve conflicts.
This feature is supported in the following languages/technologies:
The instructions and examples given here address the use of the feature in C#. For details specific to other languages, see corresponding topics in the ReSharper by Language section.