XAML语法与静态资源应用

1. 引言

WPF(Windows Presentation Foundation)是一种用于构建 Windows 桌面应用程序的 UI 框架。它使用 XAML(eXtensible Application Markup Language)来定义用户界面,并支持数据绑定、样式、模板等强大功能。本笔记将重点介绍 Prism 框架、XAML 语法、静态资源的使用,以及如何为 MVVM 模式开发做准备。


2. XAML 语法基础

2.1 对象元素语法 vs 属性语法

在 XAML 中,我们可以使用两种方式来设置控件的属性:

对象元素语法(Object Element Syntax)
xml 复制代码
<Button>
    <Button.Background>
        <SolidColorBrush Color="Blue"/>
    </Button.Background>
    Click Me
</Button>
属性语法(Property Syntax)
ini 复制代码
<Button Background="Blue" Content="Click Me"/>

对比说明:

  • 属性语法更简洁,适用于简单属性设置。
  • 对象元素语法适用于复杂属性(如画刷、模板等),可以在内部嵌套其他元素。

3. 应用程序启动配置

3.1 配置 ​​App.xaml​​ 启动视图

在 ​​App.xaml​​ 中,我们可以指定应用程序启动时显示的窗口或页面:

ini 复制代码
<Application x:Class="WpfApp.App"
             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
             StartupUri="MainWindow.xaml">
</Application>

说明:

  • ​StartupUri​ 指定启动的 XAML 文件。
  • 命名空间需正确引入,否则无法找到视图。

4. 属性元素语法与复杂画刷

4.1 使用属性元素语法设置复杂画刷

ini 复制代码
<Button Content="彩色按钮">
    <Button.Background>
        <LinearGradientBrush>
            <GradientStop Color="Yellow" Offset="0.0"/>
            <GradientStop Color="Red" Offset="1.0"/>
        </LinearGradientBrush>
    </Button.Background>
</Button>

优势:

  • 支持更复杂的视觉设计。
  • 可实现渐变、图像画刷等效果。

5. 静态资源与样式复用

5.1 定义静态资源

在 ​​App.xaml​​ 或某个 Window/UserControl 的资源字典中定义:

ini 复制代码
<Window.Resources>
    <SolidColorBrush x:Key="MyBackground" Color="LightBlue"/>
    <Style x:Key="MyButtonStyle" TargetType="Button">
        <Setter Property="Background" Value="{StaticResource MyBackground}"/>
        <Setter Property="FontSize" Value="16"/>
    </Style>
</Window.Resources>

5.2 使用静态资源

ini 复制代码
<Button Style="{StaticResource MyButtonStyle}" Content="样式按钮"/>

优点:

  • 实现样式复用,统一界面风格。
  • 便于维护和主题切换。

6. ​​Name​​​ 与 ​​x:Name​​ 的区别与选择

6.1 两者对比

属性 使用场景 备注
​Name​ 用于 WPF 内置控件(如 Button) 部分控件不支持
​x:Name​ 通用,适用于所有元素 推荐使用,确保一致性和兼容性

6.2 示例

ini 复制代码
<Button x:Name="btnSubmit" Content="提交"/>
<TextBlock Name="txtMessage" Text="Hello"/>

推荐使用​x:Name​

  • 保证在代码后台中能正确引用控件。
  • 兼容视觉树查找与模板中的控件。

7. 数据模板简介

7.1 定义数据模板

ini 复制代码
<Window.Resources>
    <DataTemplate DataType="{x:Type local:Student}">
        <StackPanel Orientation="Horizontal">
            <TextBlock Text="{Binding Name}"/>
            <TextBlock Text=" - "/>
            <TextBlock Text="{Binding Age}"/>
        </StackPanel>
    </DataTemplate>
</Window.Resources>

说明:

  • 数据模板用于定义如何显示数据对象。
  • 可与 ​ItemsControl​​ListBox​ 等控件结合使用。

相关推荐
爱敲代码的北2 小时前
WPF容器控件布局与应用学习笔记
后端
清空mega2 小时前
从零开始搭建 flask 博客实验(5)
后端·python·flask
爱敲代码的北2 小时前
UniformGrid 均匀网格布局学习笔记
后端
一只叫煤球的猫2 小时前
从1996到2025——细说Java锁的30年进化史
java·后端·性能优化
喵个咪3 小时前
开箱即用的GO后台管理系统 Kratos Admin - 数据脱敏和隐私保护
后端·go·protobuf
我是天龙_绍3 小时前
Java Object equal重写
后端
虎子_layor3 小时前
实现异步最常用的方式@Async,快速上手
后端·spring
一米阳光zw3 小时前
Spring Boot中使用 MDC实现请求TraceId全链路透传
java·spring boot·后端·traceid·mdc
王元_SmallA4 小时前
pgsql:connection failed connection to server at
java·后端