- XAML Tutorial
- XAML - Home
- XAML - Overview
- XAML - Environment Setup
- Writing XAML Aplication On MAC OS
- XAML Vs C# Code
- XAML Vs.VB.NET
- XAML - Building Blocks
- XAML - Controls
- XAML - Layouts
- XAML - Event Handling
- XAML - Data Binding
- XAML - Markup Extensions
- XAML - Dependency Properties
- XAML - Resources
- XAML - Templates
- XAML - Styles
- XAML - Triggers
- XAML - Debugging
- XAML - Custom Controls
- XAML Useful Resources
- XAML - Quick Guide
- XAML - Useful Resources
- XAML - Discussion
XAML - 标记扩展
在 XAML 应用程序中,标记扩展是一种获取既不是特定 XAML 对象也不是基元类型的值的方法/技术。标记扩展可以通过打开和关闭花括号来定义,并且在花括号内定义标记扩展的范围。
数据绑定和静态资源是标记扩展。System.xaml中有一些预定义的 XAML 标记扩展可供使用。
让我们看一个简单的示例,其中使用了StaticResources标记扩展,它是预定义的 XAML 标记扩展。
以下 XAML 代码创建两个具有某些属性的文本块,它们的前景在Window.Resources中定义。
<Window x:Class = "XAMLStaticResourcesMarkupExtension.MainWindow" xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" Title = "MainWindow" Height = "350" Width = "525"> <Window.Resources> <SolidColorBrush Color = "Blue" x:Key = "myBrush"></SolidColorBrush> </Window.Resources> <Grid> <StackPanel Orientation = "Vertical"> <TextBlock Foreground = "{StaticResource myBrush}" Text = "First Name" Width = "100" Margin = "10" /> <TextBlock Foreground = "{StaticResource myBrush}" Text = "Last Name" Width = "100" Margin = "10" /> </StackPanel> </Grid> </Window>
在Window.Resources中,您可以看到使用x:Key来唯一标识在 XAML 定义的字典中创建和引用的元素,以标识资源字典中的资源。
当你编译并执行上面的代码时,它将产生以下MainWindow。您可以看到两个前景色为蓝色的文本块。
在XAML中,还可以通过继承MarkupExtension类并重写ProvideValue方法来定义自定义标记扩展,该方法是MarkupExtension类中的抽象方法。
让我们看一个自定义标记扩展的简单示例。
<Window x:Class = "XAMLMarkupExtension.MainWindow" xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" xmlns:my = "clr-namespace:XAMLMarkupExtension" Title = "MainWindow" Height = "350" Width = "525"> <Grid> <Button Content = "{my:MyMarkupExtension FirstStr = Markup, SecondStr = Extension}" Width = "200" Height = "20" /> </Grid> </Window>
在上面的 XAML 代码中,使用一些属性创建了一个按钮,对于内容值,使用了自定义标记扩展(my:MyMarkupExtension),并使用了两个值“Markup”和“Extension”,分别分配给 FirstStr 和 SecondStr。
实际上,MyMarkupExtension
它是一个派生自MarkupExtension
C# 实现的类,如下所示。此类包含两个字符串变量 FirstStr 和 SecondStr,它们连接起来并将该字符串从 ProvideValue 方法返回到按钮的 Content。
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows; using System.Windows.Controls; using System.Windows.Data; using System.Windows.Documents; using System.Windows.Input; using System.Windows.Markup; using System.Windows.Media; using System.Windows.Media.Imaging; using System.Windows.Navigation; using System.Windows.Shapes; namespace XAMLMarkupExtension { /// <summary> /// Interaction logic for MainWindow.xaml /// </summary> public partial class MainWindow : Window { public MainWindow() { InitializeComponent(); } } public class MyMarkupExtension : MarkupExtension { public MyMarkupExtension() { } public String FirstStr { get; set; } public String SecondStr { get; set; } public override object ProvideValue(IServiceProvider serviceProvider) { return FirstStr + " " + SecondStr; } } }
让我们运行这个应用程序,您可以立即在主窗口中看到“标记扩展”已成功用作按钮的内容。