Coding Assistance in XAML
Most of JetBrains Rider's coding assistance features are also supported in XAML. You can find the detailed information on these features in the corresponding topics of the Coding assistance section.
In this topic, you can find some examples of using coding assistance features in XAML.
JetBrains Rider highlights classes, fields, properties, events, and so on with different colors, so that they can be distinguished easily.
data:image/s3,"s3://crabby-images/0d5dc/0d5dcc9a3f282f1fc5156de3bf377634d30fb279" alt="JetBrains Rider: Syntax highlighting in XAML JetBrains Rider: Syntax highlighting in XAML"
You can establish a custom color scheme. For more information, refer to Colors schemes: fonts and colors of IDE text.
JetBrains Rider highlights color usages with corresponding color and shows additional information on the tooltip. You can also press AltEnter on a highlighted color usage, choose Pick color from palette and define a color using a visual palette.
data:image/s3,"s3://crabby-images/7c4eb/7c4eb6c787d7b1ba83c1559d55559b6760781df5" alt="JetBrains Rider: Color assistance in XAML JetBrains Rider: Color assistance in XAML"
Inlay hints are available in XAML for markup property names and DataContext
, as well as for margins and paddings.
You can toggle the following hints for XAML on the Editor | Inlay Hints | XAML page of JetBrains Rider settings CtrlAlt0S:
JetBrains Rider provides a couple of useful features that can save your efforts on typing. So you write more code with less keystrokes.
synchronous tag editing — any change of the opening tag is simultaneously applied to the closing tag and vice versa
smart slash — as soon as you type the slash at the end of an opening tag, the tag is automatically converted to the empty one
JetBrains Rider provides a full set of code completion features as well. So you can complete tags:
data:image/s3,"s3://crabby-images/b1aa7/b1aa722e4ad393b1bcaf2e8a1a7fc74eaf833a8b" alt="JetBrains Rider: Code completion in XAML JetBrains Rider: Code completion in XAML"
And attributes in XAML:
data:image/s3,"s3://crabby-images/1d191/1d1914a1d90f5631860ab75f5c010ae8897c6cfa" alt="JetBrains Rider: CCode completion in XAML JetBrains Rider: CCode completion in XAML"
Moreover, JetBrains Rider suggests appropriate symbols and actions depending on the context:
data:image/s3,"s3://crabby-images/1f30d/1f30d2cc41ab257f5f99f23a873b4478714da8cb" alt="JetBrains Rider: Code completion in XAML JetBrains Rider: Code completion in XAML"
Also, you can complete closing tags. JetBrains Rider provides the list of tags that are not closed at the current caret position.
JetBrains Rider provides a set of context actions that target XAML code. You can find the full list of these actions in the Editor | Context actions | XAML page of JetBrains Rider Settings. If necessary, you can also disable some of the actions using this page.
As soon as a context action becomes available for the current caret position, JetBrains Rider displays the corresponding action indicator to the left of the caret. Sometimes however, JetBrains Rider provides several contextually available features for the current caret position. In this case, the action indicator corresponding to the action with the highest priority is shown, and all other actions only appear when you expand the action list by clicking on the action indicator or pressing AltEnter Context actions have the lowest priority, therefore, they often appear at the bottom of the action list.
Here are some examples of context actions for XAML:
If you want to convert an attribute to a nested element, use this context action.
data:image/s3,"s3://crabby-images/d3243/d3243c24fc5069cd3cf4fdbb1a61a20be4ce83e7" alt="JetBrains Rider: Convert attribute to nested element context action in XAML JetBrains Rider: Convert attribute to nested element context action in XAML"
After applying this context action, the attribute is converted to a child tag with the same value, so that you can provide a more complex value for the property.
data:image/s3,"s3://crabby-images/3a88f/3a88f94f00f63a8d981ceec025c3a32628bfc5ec" alt="JetBrains Rider: Convert attribute to nested element context action in XAML JetBrains Rider: Convert attribute to nested element context action in XAML"
If the value of a property is simple, there is no need to have it in a separate tag, so you can convert it to an attribute using this context action.
data:image/s3,"s3://crabby-images/cde07/cde07ffaefe623e9b5dff556896d09c81d005e52" alt="JetBrains Rider: 'Convert tag to an attribute' context action in XAML JetBrains Rider: 'Convert tag to an attribute' context action in XAML"
After applying this context action, the tag is converted to the attribute.
data:image/s3,"s3://crabby-images/10ba6/10ba6edec3b06cffc248558b686d39ea8cacbbc0" alt="JetBrains Rider: 'Convert tag to an attribute' context action in XAML JetBrains Rider: 'Convert tag to an attribute' context action in XAML"