Win10系列:UWP界面布局基础6
资源合并
前面提到过,可以将资源字典定义在单独的XAML文件中,这样的文件被称为资源字典文件。那么,在需要引用文件中的资源时可以通过ResourceDictionary元素的MergedDictionaries属性将资源字典文件合并到指定位置。
例如,要把两个XAML文件ResourceFile1.xaml和ResourceFile2.xaml中的资源字典合并到应用程序的资源字典当中,这时需要打开现有项目中的App.xaml文件,然后把这两个资源字典文件合并到Application节点下,相应的XAML代码片段如下所示:
<Application>
<Application.Resources>
<ResourceDictionary>
<ResourceDictionary.MergedDictionaries>
<ResourceDictionary Source="ResourceFile1.xaml"/>
<ResourceDictionary Source="ResourceFile2.xaml"/>
</ResourceDictionary.MergedDictionaries>
</ResourceDictionary>
</Application.Resources>
</Application>
在上面的代码中,通过ResourceDictionary元素的Source属性指定资源字典文件的URI。这样,资源字典文件ResourceFile1.xaml和ResourceFile2.xaml中的资源将可以在整个应用程序的范围内使用。
3.2.7 依赖项属性和附加属性
在3.2.3节中已经介绍了属性的概念,以及设置元素的属性时常用的方法。本小节将主要介绍XAML中两种典型的属性:依赖项属性和附加属性。
1.依赖项属性
如果属性的值依赖于其他的数据源,那么将这个属性称为依赖项属性。因此,依赖项属性的一个显著特点是属性值依赖于一个或多个数据源,并且这些数据源的提供方式可以不同,例如通过数据绑定提供数据源,或者通过动画、模板、样式等方式提供数据源等。
不过,在对依赖项属性进行赋值时,不同的数据源提供方式控制依赖项属性的优先权是不同的。下面来了解一下动画、模板、样式和数据绑定等方式的优先权级别,如图3-9所示,按照优先级由低到高的顺序将这几类方式进行排序。

图3-9 不同方式的优先级排序
从图中可以看出,动画设置首先得到依赖项属性的控制权;其次是对依赖项属性的一些本地化操作,如本地赋值、数据绑定和资源引用;在没有提供其他任何数据源的情况下,才采用默认赋值方式为依赖项属性赋值。
下面以样式和本地赋值为例,来演示不同的数据源提供方式将如何影响依赖项属性的属性值。
新建一个Windows应用商店的空白应用程序项目,将其命名为DependentAttributeApplication。双击打开MainPage.xaml文件,在Grid元素中添加如下XAML代码片段:
<Grid.Resources>
<Style x:Key="ButtonStyle" TargetType="Button">
<Setter Property="Foreground" Value="Red"/>
<Setter Property="FontSize" Value="24"/>
</Style>
</Grid.Resources>
<Button Content="确定" Style="{StaticResource ButtonStyle}" Margin="100" Height="50"/>
<Button Content="取消" Style="{StaticResource ButtonStyle}" Margin="228,359,0,359" Height="50" Foreground="Yellow" FontSize="14"/>
在上面的代码中,首先定义一个按钮样式资源,键为ButtonStyle,在样式中通过Setter元素设置按钮的文本颜色为红色,字体大小为24像素;然后添加了两个按钮,Content属性值分别为"确定"和"取消",并使用StaticResource标记扩展引用键为"ButtonStyle"的样式资源分别赋值给这两个按钮的Style属性,同时还通过本地赋值方式设置"取消"按钮的文本颜色为黄色,字体大小为14像素。
启动调试,可以看到"确定"按钮采用了样式ButtonStyle,生成了相应的外观效果,而"取消"按钮的Forground和FontSize属性的数据源提供方式中,本地赋值优先于控件样式,因采用本地赋值而生成了不同的外观,效果如图3-10所示。。

图3-10 不同的数据源提供方式对属性值产生的影响
Win10系列:UWP界面布局基础6的更多相关文章
- Win10系列:UWP界面布局基础1
随着技术的不断发展,使用者对应用程序的界面体验提出了更高的要求,为了应对越来越复杂的界面设计需求和有效的简化界面开发过程,微软公司在其应用程序的开发技术当中引入一套新的应用程序界面描述语言,这就是XA ...
- Win10系列:UWP界面布局基础8
路由事件 XAML不仅继承了传统的事件处理方式,还引入了一个增强型事件处理机制:路由事件(RoutedEvent).路由事件和传统事件的不同是:路由事件允许一个对象触发事件后,可以同时拥有多个事件接收 ...
- Win10系列:UWP界面布局基础7
2.附加属性 有一些XAML元素,其自身的属性大多是在其它的元素中声明和使用的,该元素本身却很少使用,这些在其他元素中声明和使用的属性被称为附加属性(Attached Properties).附加属性 ...
- Win10系列:UWP界面布局基础4
类型转换 前面讲到过,在定义元素时可以通过Attributes特性方式为其设置属性并为属性赋值,在实际开发中所赋予的值可能和属性本身的数据类型不相符,这时XAML解析器就会使用类型转换器(Type C ...
- Win10系列:UWP界面布局基础2
属性设置 在面向对象程序开发中,所提及的属性通常指的是对象的属性.在XAML代码中,定义元素时也可以为其设置属性,例如对于一个TextBox元素,有背景属性.宽度属性和高度属性等.为了满足实际应用的需 ...
- Win10系列:UWP界面布局基础12
画刷 画刷(Brush)用于为图形元素填充颜色.在XAML中,画刷有许多属性,其中较常使用的是Fill属性和Stroke属性,Fill用于填充图形的背景色,而Stroke用于设置图形的线条颜色. 在实 ...
- Win10系列:UWP界面布局基础11
样式继承 为了使样式便于维护及重复使用,可以在一个样式上引用其他的样式,这就是样式继承.样式继承的方法是:在Style元素的BasedOn属性上使用StaticResource标记扩展来引用被继承的样 ...
- Win10系列:UWP界面布局基础5
(2)编写后台代码访问资源 下面通过一个例子来演示如何编写后台代码引用资源.新建一个Windows应用商店的空白应用程序项目,将其命名为AccessResourceApplication,打开项目下的 ...
- Win10系列:UWP界面布局基础3
在实际项目开发中,为控件属性赋值时经常会遇到属性值在设计时处于未知状态,而只有在应用程序运行时才能获取到.这种情况下,直接赋值方法是无法满足的,可以使用XAML标记扩展(Markup Extensio ...
- Win10系列:UWP界面布局基础9
在XAML中,样式.模板.画笔和动画等都被看做是资源,它们最终的作用都是相同的,就是让设计人员可以使用这些资源创建更好的视觉效果,对其设计的产品外观进行标准化统一,那么如何使用这些资源并组织和重用呢, ...
随机推荐
- 修改记录-优化后(springboot+shiro+session+redis+ngnix共享)
1.普通用户实现redis共享session 1.配置 #cache指定缓存类型 spring.cache.type=REDIS #data-redis spring.redis.database=1 ...
- jquery 手机获取验证码计时
html: <input type="text" class="codeText" id="txtverifycode" /> ...
- DirectX学习之第一个可运行的工程
学习一门开发语言的第一件事情当然是搭建一个可运行的环境,然后运行一个可成功执行的案例. 本人在学习DirectX的第一个工程的时候,参考了雨凇MoMo的一篇文章(https://www.xuanyus ...
- 虚拟机vmnet0、vmnet1和vmnet8的区别
vmnet0,实际上就是一个虚拟的网桥 vmnet0,实际上就是一个虚拟的网桥,这个网桥有很若干个端口,一个端口用于连接你的Host,一个端口用于连接你的虚拟机,他们的位置是对等的,谁也不是谁的网关. ...
- seo中的竞价排名是什么
seo中的竞价排名是什么 一.总结 一句话总结:竞价排名的基本特点是按点击付费,推广信息出现在搜索结果中(一般是靠前的位置),如果没有被用户点击,则不收取推广费. 搜索引擎的一种推广广告的方式 1.竞 ...
- Servlet 小知识
1.In servlet 3.0 we have new feature annotations to replace XML.也就是说应该尽量使用annotations Servlet is an ...
- boke练习: spring boot: security post数据时,要么关闭crst,要么添加隐藏域
spring boot: security post数据时,要么关闭crst,要么添加隐藏域 http.csrf().disable(); 或者: <input name="${_cs ...
- [Win10]安装msi时2503,2502错误及其解决
简述 刚安装了win10系统,在安装TortoiseGit和TortoiseSvn时,这两个软件是.msi后缀的安装文件,在点击安装时老是提示2503,2502错误,因此无法安装上 搜索了下一般都提到 ...
- 如何有效地使用t-SNE | How to Use t-SNE Effectively
熟练使用PCA和tSNE,彻底理解底层的原理是非常有必要的. 参考:How to Use t-SNE Effectively Real-time tSNE Visualizations with Te ...
- Squid代理配置
更改squid错误页面时间不对的问题解压源码包,进入此路径/usr/local/squid/share/errors/zh-cn(需要更改该目录下的所有文件find -type f |xargs se ...