XAML 给资源起个好名字 用 StaticResource 起一个别名
本文来和大家聊一下关于 XAML 资源的定义的事情,和开发技术关系不大,更多的是开发的思路
在稍微大一点的项目里,肯定 XAML 资源是少不了的。对于 XAML 资源,行业里讨论多(非小白讨论)的是关于资源的复用和初始化时机,加载时机的问题。本文聊的是资源的复用以及变更资源的开发模式
如果团队里有一位开发者是命名高手,那么问题将特别小。或者说这个项目只有一位开发者在开发,也不需要后续维护,那这个问题也特别的小。然而在很多团队里面,都有很多开发者,同时开发者的命名能力也有一定的差距
如果没有给资源一个好的命名,自然,每次用起来的时候,都会遇到一个问题,那就是某个资源找不到的问题。一旦找不到资源,自然就只能重新定义资源了。或者说我以为某个资源是我此模块能用的,然而此资源却非通用设计,也许下个版本就被更改,于是我的模块就因为某个资源的变更而挖坑
如下面的例子:
我需要开发一个应用,此应用有多个页面组合。由于技术侧的问题,我不能将每个页面都使用相同的控件,需要采用不同的控件。但是为了界面的美观,尽管使用的不同的控件,依然也需要保持相似页面布局方式。按照惯例,假定定义页面的内边距,假设默认的页边距是 12 单位大小,定义为资源可以如何写?如以下的资源定义
<Thickness x:Key="TwelveThickness">12,12,12,12</Thickness>
可以看到,定义资源为 12 单位的 Thickness 有点过于具体了。如果后续设计师想改为 16 个单位呢?那此时就是一个选择了,要么将此资源改为 16 的值,但是保留 TwelveThickness 这个词,让其他的开发者看到这里虽然写着是 Twelve 但实际上是 16 个单位。要么就是改值和改资源名,说不定就是炸鱼的改动了。要么就是再新加一个资源名,也许这样垃圾就加一了
如果有一个具体的命名呢?命名和数值无关的呢?例如命名为 MainPagePadding 呢?这个感觉是不错的,给主页面使用的 Padding 值。但是不够抽象,如果我用的是 FxxPage 的呢,这个也需要一个内边距,那用哪个资源好呢
如果定义的资源命名是 DefaultPagePadding 呢,或者 PagePadding 呢,是不是就更抽象了一层,不仅 MainPage 能用,也合适 FxxPage 使用
但是定义的抽象等级,除非是命名高手,否则一次性叫对一个命名还是很有难度的。而有一些资源,又是十分冲突的。既是非常通用的,却也许会被变更。例如颜色,定义颜色画刷的时候,资源的重复存在的问题核心就是开发模式上的寻找困难和被其他开发者更改带来的锅,在性能上的问题就是非托管资源的占用增加,没有复用原有的画刷。但是颜色的定义,是会在迭代被变更的
从技术侧的一个解决方法是采用 StaticResource 来进行资源的引用,相当于给资源一个别名的方式。再定义一个资源,引用原先的资源
例如有一个红色是默认的主题红色,最好的定义是 Brush.SolidColorBrush.RedThemeBrush 的资源名。然而此资源名特别具体,如果作为主页面的背景色的时候,此时将会因为太过具体而不合适。毕竟后续如果我还有其他的页面,似乎用来做背景的,耦合了具体的红主题色是不合适的
那如果再定义一个画刷主题,称为 MainPageBackgroundBrush 呢?自然,重复定义的画刷就是重复的资源,不合适
好在可以使用 StaticResource 的方式,使用静态资源引用,从而让资源被重新定向,如下面代码,定义了一个主题颜色
<SolidColorBrush x:Key="Brush.SolidColorBrush.RedThemeBrush" Color="#FFC10606"/>
接下来可以采用 StaticResource 引用此颜色,定义一个默认的页面的背景画刷
<StaticResource x:Key="DefaultPageBackgroundBrush" ResourceKey="Brush.SolidColorBrush.RedThemeBrush"/>
再定义具体的主页面的背景画刷
<StaticResource x:Key="MainPageBackgroundBrush" ResourceKey="DefaultPageBackgroundBrush"/>
于是在引用的时候,可以在主页面,只引用主页面的背景画刷
<Grid x:Name="MainPage" Background="{StaticResource MainPageBackgroundBrush}"></Grid>
这样做的一个优势在于,让资源的定义是一层层定义的。解决了开发侧的重复资源定义,又想资源重复定义方便改动的时候相互不影响,又想着不重复定义方便要改可以一起改的问题
如以上的代码,相当于将资源的定义分为三层。最底层是 Brush.SolidColorBrush.RedThemeBrush 定义一个和业务无关的画刷,第二层是 DefaultPageBackgroundBrush 定义和页面有关的默认画刷,最上层是 MainPageBackgroundBrush 定义和主页面相关的画刷
这些画刷都是相同的一个资源,只是靠 StaticResource 进行引用
如果后续准备改主页面的画刷,而其他的页面保持不动。那么可以明确了解到,只需要改 MainPageBackgroundBrush 的资源值即可,影响不到其他的页面。而如果期望是全部页面的背景色都换成某个其他的颜色,只需要改 DefaultPageBackgroundBrush 即可。如果是设计师想要改整个应用的红色主题色,那就改 Brush.SolidColorBrush.RedThemeBrush 的颜色
如此的设计可以比较方便解决比较大的项目的资源引用问题。核心的思想就是依靠引用的方式,将资源的定义分层,按照抽象的不同,分为不同层的定义。定义资源的命名方式最好都是一组一组的,一个抽象层里面有很多组,每一组之间的命名都是非常相似的。如此就很方便资源的管理。这只是一个思想,不使用 StaticResource 也可以,如换成绑定的方式也可以
XAML 给资源起个好名字 用 StaticResource 起一个别名的更多相关文章
- spring mvc问题:源服务器未能找到目标资源的表示或者是不愿公开一个已经存在的资源表示
HTTP状态 404 - 未找到 类型 状态报告 描述 源服务器未能找到目标资源的表示或者是不愿公开一个已经存在的资源表示. 我的问题:spring mvc无法访问到映射的controller,页面显 ...
- WPF在XAML的资源中定义空字符串String.Empty
代码如下: <!--1. 首先引用System的命名空间--> <Window x:Class="DriverEasyWPF.Views.DialogWindow" ...
- WPF学习一:XAML的资源(Resources)结构
一个初学者,把知识做个积累,如果有不对的地方,还请高手指出,谢谢! 先看一段代码:(下面是以Window WPF进行讲解,如果是Web 的话就把<Window改为<Page 而如果是 Us ...
- WPF_在APP.xaml应用资源样式
先上代码: <Application x:Class="NetAnalysis.App" xmlns="http://schemas.microsoft.com/w ...
- 在一个XAML中点击按钮,界面跳转到另一个XAML界面方法
private void ButtonGo_camerapage(object sender, RoutedEventArgs e) { this.Content = new cameraPage() ...
- Visual Studio下,打开资源视图rc文件,提示在另一个编辑器中打开
在网上搜索关键字: rc文件 提示在另一个编辑器中打开 很多地方的回答都是说: rc文件以代码形式打开了,只要关掉后再打开就可以了. 但是,很多时候,当关闭掉RC的代码文件以后,发现VS的RC文件 ...
- VC++ MFC工程中中如何将一个工程的资源(如对话框)复制到另外一个工程
问题的提出:在工程1中用到的资源,在工程2中已有现成的.即工程1中要用到的对话框和工程2的完全相同,而工程2中对该对话框的布局已设计好.控件变量都绑定好了.但由于该对话框的控件特别多,如果在工程1中再 ...
- Tomcat访问项目出现HTTP状态404-未找到,类型 状态报告 描述 源服务器未能找到目标资源的表示或者是不愿公开一个已经存在的资源表示。Apache Tomcat/9.0.40
错误提示如图,无任何消息提示,控制台也没有错误. 解决方法: IDEA,上方菜单栏点击Run–>Edit Configurations-,选择Deployment,将Application co ...
- XAML概览 1(译自JeremyBytes.com)
(文章译自JeremyBytes.com,由于原文太长,故分成几篇,能力所限,如有疏漏,希望海涵.另外若有侵权,务必尽快告知) Overview 了解XAML (可扩展应用程序标记语言)是使用WPF和 ...
- Windows Phone 8本地化多语言支持
原文 Windows Phone 8本地化多语言支持 在WP8平台处理本地化多语言的支持还是比较容易的,大部分工作都有VS IDE处理,开发者只需简单操作,并翻译本地资源即可实现. 无论您目前的应用是 ...
随机推荐
- 用Vue3.0 写过组件吗?如果想实现一个 Modal你会怎么设计?
这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 一.组件设计 组件就是把图形.非图形的各种逻辑均抽象为一个统一的概念(组件)来实现开发的模式 现在有一个场景,点击新增与编辑都弹框出来进行 ...
- 记录--vue3问题:如何实现微信扫码授权登录?
这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 一.需求 微信扫码授权,如果允许授权,则登录成功,跳转到首页. 二.问题 1.微信扫码授权有几种实现方式? 2.说一下这几种实现方式的原理 ...
- 记录-JS 基础知识大全
这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 1.通过javascript向文档中输出文本 document是javascript的内置对象,代表浏览器的文档部分 document.w ...
- 基于ARM联合ZYNQ的设计小结
基于ARM联合ZYNQ的设计小结 1.硬件设计 硬件设计就是使用PS的自带硬核,外接其他可以连接AXI的IP核,构成一个自定义的硬件平台.如果简单理解,可以把这些操作统称为底层.这部分的设计还是比较方 ...
- KingbaseES V8R6集群运维案例-- 备库数据库服务意外down分析
案例说明: KingbaseES V8R6一主二备架构的集群,两个备库节点sys_log日志分别不同时间点收到'fast shutdown request'的日志信息,导致备库数据库服务down,需要 ...
- KingbaseES V8R6集群运维案例之---securecmdd工具usePAM配置
案例说明: 默认在部署securecmdd工具后,在配置文件securecmdd_config中配置参数usePAM=yes,在有的系统主机环境,会导致securecmd客户端连接失败. 适用版本: ...
- KingbaseES中truncate和oracle中truncate区别
truncate命令在KingbaseES中本质上区别于oracle.因为oracle中,数据文件datafile可以被表所共享,每张表被分配各自的连续的extents.而在KingbaseES中,数 ...
- 初学 FSMC - 外扩SRAM(二)
1. FSMC简介 STM32F4系列芯片使用FSMC外设来管理扩展的存储器, FSMC是Flexible Static Memory Controller的缩写,译为灵活的静态存储控制器.它可以 ...
- Linux之驱动管理
一.相关概念 驱动概念 驱动与底层硬件直接打交道,充当了硬件与应用软件中间的桥梁. 将驱动程序载入内核,应用程序可以通过系统调用接口来访问(驱动)底层的硬件设备. 驱动功能 对设备初始化和释放 把数据 ...
- mmdetection使用wandb查看训练日志
mmdetection查看日志之前一直是在用TextLoggerHook,已经觉得挺方便的了,自从用了wandb之后,发现wandb真不错,看log更方便了,回不去了. wandb的简单配置: wan ...