Kaganapan
Mar 17, 9 PM - Mar 21, 10 AM
Sumali sa serye ng meetup upang bumuo ng mga scalable AI solusyon batay sa mga kaso ng paggamit ng tunay na mundo sa mga kapwa developer at eksperto.
Magparehistro naHindi na suportado ang browser na ito.
Mag-upgrade sa Microsoft Edge para samantalahin ang mga pinakabagong tampok, update sa seguridad, at teknikal na suporta.
Defines and references keys for resources that are loaded from external assemblies. This enables a resource lookup to specify a target type in an assembly, rather than an explicit resource dictionary in an assembly or on a class.
<object x:Key="{ComponentResourceKey {x:Type targetTypeName}, targetID}" ... />
<object x:Key="{ComponentResourceKey TypeInTargetAssembly={x:Type targetTypeName}, ResourceID=targetID}" ... />
<object property="{DynamicResource {ComponentResourceKey {x:Type targetTypeName}, targetID}}" ... />
<object property="{DynamicResource {ComponentResourceKey TypeInTargetAssembly={x:Type targetTypeName}, ResourceID=targetID}}" ... />
Value | Description |
---|---|
targetTypeName |
The name of the public common language runtime (CLR) type that is defined in the resource assembly. |
targetID |
The key for the resource. When resources are looked up, targetID will be analogous to the x:Key Directive of the resource. |
As seen in the usages above, a {ComponentResourceKey
} markup extension usage is found in two places:
The definition of a key within a theme resource dictionary, as provided by a control author.
Accessing a theme resource from the assembly, when you are retemplating the control but want to use property values that come from resources provided by the control's themes.
For referencing component resources that come from themes, it is generally recommended that you use {DynamicResource}
rather than {StaticResource}
. This is shown in the usages. {DynamicResource}
is recommended because the theme itself can be changed by the user. If you want the component resource that most closely matches the control author's intent for supporting a theme, you should enable your component resource reference to be dynamic also.
The TypeInTargetAssembly identifies a type that exists in the target assembly where the resource is actually defined. A ComponentResourceKey
can be defined and used independently of knowing exactly where the TypeInTargetAssembly is defined, but eventually must resolve the type through referenced assemblies.
A common usage for ComponentResourceKey is to define keys that are then exposed as members of a class. For this usage, you use the ComponentResourceKey class constructor, not the markup extension. For more information, see ComponentResourceKey, or the "Defining and Referencing Keys for Theme Resources" section of the topic Control Authoring Overview.
For both establishing keys and referencing keyed resources, attribute syntax is commonly used for the ComponentResourceKey
markup extension.
The compact syntax shown relies on the ComponentResourceKey constructor signature and positional parameter usage of a markup extension. The order in which the targetTypeName
and targetID
are given is important. The verbose syntax relies on the ComponentResourceKey parameterless constructor, and then sets the TypeInTargetAssembly and ResourceId in a way that is analogous to a true attribute syntax on an object element. In the verbose syntax, the order in which the properties are set is not important. The relationship and mechanisms of these two alternatives (compact and verbose) is described in more detail in the topic Markup Extensions and WPF XAML.
Technically, the value for targetID
can be any object, it does not have to be a string. However, the most common usage in WPF is to align the targetID
value with forms that are strings, and where such strings are valid in the XamlName Grammar.
ComponentResourceKey
can be used in object element syntax. In this case, specifying the value of both the TypeInTargetAssembly and ResourceId properties is required to properly initialize the extension.
In the WPF XAML reader implementation, the handling for this markup extension is defined by the ComponentResourceKey class.
ComponentResourceKey
is a markup extension. Markup extensions are typically implemented when there is a requirement to escape attribute values to be other than literal values or handler names, and the requirement is more global than just putting type converters on certain types or properties. All markup extensions in XAML use the { and } characters in their attribute syntax, which is the convention by which a XAML processor recognizes that a markup extension must process the attribute. For more information, see Markup Extensions and WPF XAML.
Feedback sa .NET Desktop feedback
Ang .NET Desktop feedback ay isang open source na project. Pumili ng link para magbibigay ng feedback:
Kaganapan
Mar 17, 9 PM - Mar 21, 10 AM
Sumali sa serye ng meetup upang bumuo ng mga scalable AI solusyon batay sa mga kaso ng paggamit ng tunay na mundo sa mga kapwa developer at eksperto.
Magparehistro naPagsasanay
Module
Design consistent .NET MAUI XAML pages by using shared resources - Training
Learn how to use static and dynamic shared resources to build a .NET Multi-platform App UI (MAUI) user interface. And see how styles can make the user interface both consistent and accessible.
Dokumentasyon
TemplateBinding Markup Extension - WPF .NET Framework
Learn about the TemplateBinding Markup Extension.
ResourceDictionary and XAML resource references - Windows apps
Explains how to define a ResourceDictionary element and keyed resources, and how XAML resources relate to other resources that you define as part of your app or app package.
ColorConvertedBitmap Markup Extension - WPF .NET Framework
Learn about the ColorConvertedBitmap markup XAML extension of Windows Presentation Foundation (WPF).