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​ 等控件结合使用。

相关推荐
vipbic5 分钟前
Strapi 5 怎么用才够爽?这款插件带你实现“建站自由”
后端·node.js
苏三的开发日记43 分钟前
linux搭建hadoop服务
后端
sir7611 小时前
Redisson分布式锁实现原理
后端
大学生资源网1 小时前
基于springboot的万亩助农网站的设计与实现源代码(源码+文档)
java·spring boot·后端·mysql·毕业设计·源码
苏三的开发日记1 小时前
linux端进行kafka集群服务的搭建
后端
苏三的开发日记2 小时前
windows系统搭建kafka环境
后端
爬山算法2 小时前
Netty(19)Netty的性能优化手段有哪些?
java·后端
Tony Bai2 小时前
Cloudflare 2025 年度报告发布——Go 语言再次“屠榜”API 领域,AI 流量激增!
开发语言·人工智能·后端·golang
想用offer打牌2 小时前
虚拟内存与寻址方式解析(面试版)
java·后端·面试·系统架构
無量2 小时前
AQS抽象队列同步器原理与应用
后端