WPF之资源(Resources)

时间:2025-04-16 22:50:08
  1. 什么是资源:

资源是可以在应用程序的不同位置重用的对象。XAML资源的示例包括画笔和样式。每个框架级别的元素(FrameworkElement或FrameworkContentElement)都有一个resource属性,该属性包含资源定义的资源(作为ResourceDictionary)。可以在任何元素上定义资源,但是资源通常是在根元素上定义的。当在页面根元素上定义一个资源时,页面逻辑树中的所有元素都可以访问它,并且您可以重用相同的资源来设置接受该资源表示的类型的任何属性的值。

可以将资源引用为静态资源或动态资源。这可以通过使用StaticResource标记扩展或DynamicResource标记扩展来实现。通过替换已定义资源的值,StaticResource为属性提供了一个值,DynamicResource将属性值延迟为资源的运行时引用,从而为属性提供一个值。动态资源引用在每次访问此类资源并在运行时访问对象图时强制执行新的查找。为了获得这种访问,WPF属性系统中的依赖属性支持DynamicResource概念,并计算表达式。因此,只能对依赖项属性目标使用DynamicResource。

因此,资源的定义概括几点如下:

  1. 与传统WEB应用中CSS样式表类似
  2. 目的为了实现对象的重复使用
  3. 有助于XAML代码重用,有助于应用维护的一致性
  4. 定义资源的语法格式:

          <根元素对象.Resources>

               <资源定义>

          </根元素对象.Resources>

代码示例:

1

2

3

4

5

<Grid.Resources>

    <ImageBrush x:Key="imgBrush" Source="Images/bg01.png"/>

</Grid.Resources>

<!‐‐引用静态资源‐‐>

<Button Style="{StaticResource imgBrush}" Height="100"/>

       2. 资源字典(ResourceDictionary):

如果想用代码创建一个完整的WPF应用程序,可能还想用代码在该应用程序中创建任何资源。为此,创建一个新的ResourceDictionary实例,然后使用对ResourceDictionary. add .的连续调用将所有资源添加到字典中。然后,使用由此创建的ResourceDictionary在页面范围或中出现的元素上设置Resources属性。还可以将ResourceDictionary作为独立对象维护,而不需要将其添加到元素中。但是,如果您这样做,您必须按项目键访问其中的资源,就好像它是一个通用字典一样资源字典中的每个资源必须有一个惟一的键。在标记中定义资源时,通过x: key指令分配惟一的键。通常,键是字符串;但是,也可以通过使用适当的标记扩展将其设置为其他对象类型。定义资源之后,可以使用指定键名的资源标记扩展语法引用要用于属性值的资源

资源应用域不同,XAML资源可分为和 :

  • 是将资源对象应用于同一个对象数的不同对象上,称之为页面资源,通常被定义在XAML页面根元素上。
  • 是贯穿整个应用级别的资源,通常被定义在页面 。

所有的资源项在最终都会被整合到Resource Dictionary中的,也就是说无论是FrameworkElement的Resources,还是Window的Resources,还是Application的Resources,还是特定的ResourceDictionary中定义的resources在整个应用编译执行的时候实际上他们都在一起的作为可遍历集合共同存在于一个相对会话空间内的。 我们也提到过Resource的key是可以被允许有相同的,这样在遍历不同相对地址的Resource Dictionary时会根据StaticResource或者DynamicResource的lookup behavior来确定哪个有效。通常为了维护和灵活性的考虑,我们通常会将Resource Dictionary文件分成好几个,但在某些场合下我们只需要用其中某些资源,那么我么可以将资源从几个独立的文件中提取并合并。部分页面的代码如下:

1

2

3

4

5

6

7

8

 

<Application.Resources>

    <ResourceDictionary>

        <ResourceDictionary.MergedDictionaries>

            <!‐‐引用静态资源‐‐>

            <ResourceDictionary Source="">

        </>

    </ResourceDictionary>

</Application.Resources>