Version: 2021.2
Set up the Canvas
Inline styles vs style sheets

Runtime UI vs Editor Extension Authoring

By default, UI Builder assumes UI is being created for use at runtime in a Player build. As such, all new UI Documents (UXML) created in the UI Builder have a setting saved within the UXML that marks them as runtime-only UI. The main effect this has in the UI Builder is that the Library pane’s Standard tab will be filtered to only contain elements that work best at runtime.

Enable Editor Extension Authoring for UI Documents (UXML)

To create UI for the Unity Editor, like custom Editor Windows or custom Inspectors, you must enable Editor Extension Authoring on your UI Document (UXML). You can enable extension authoring in two ways:

  1. Select the Canvas header, and in the Inspector enabling the Document Settings > Editor Extension Authoring option:

EditorExtensionAuthoringPanelSettings

Unlike the other Canvas settings, this setting will be saved as part of the UI Document (UXML) using a <UXML> root tag attribute called editor-extension-mode.

  1. In the menu on the Library pane, select Editor Extension Authoring.

With Editor Extension Authoring enabled, you should have additional elements in the Library pane Standard tab. Editor-only elements are marked with an Editor Only pill.

Set default Editor Extension Authoring mode for new UI Documents (UXML)

To set the default setting for Editor Extension Authoring on new UI Documents (UXML):

  1. Go to Project Settings > UI Builder
  2. Select Enable Editor Extension Authoring by Default.

The Editor Extension Authoring attribute

Every UI Document (UXML) opened in UI Builder has an Editor Extension Authoring attribute. The UI Builder adds the attribute to the UI Document root tag, like the following example:

<ui:UXML xmlns:ui="UnityEngine.UIElements" xmlns:uie="UnityEditor.UIElements" editor-extension-mode="False">
注意
Because the Editor extension authoring attribute is saved in the UI Document (UXML) file, it’s version controlled. When you create a new UI Document (UXML), the UI Builder sets its Editor Extension Authoring attribute according to the default specified in the UI Builder project settings.

UI Documents (UXML) that you create outside of the UI Builder (for example, in a text editor or IDE) don’t have an Editor Extension Authoring attribute until you open them in the UI Builder. When you open an externally created UI Document (UXML) in the UI Builder for the first time, the Editor Extension Authoring attribute is set according to the default specified in the UI Builder project settings.

Set up the Canvas
Inline styles vs style sheets