<Canvas Background="#46461F"> <button WIDth="200" Height="60" Background="Red" Canvas.top="90" Canvas.left="30" Content="提 交" FontFamily="微软雅黑" FontSize="24" FontWeight="Bold" Foreground="Green"/> <button WIDth="200" Height="60" Background="Red" Canvas.top="90" Canvas.left="260" Content="取 消" FontFamily="微软雅黑" FontSize="24" FontWeight="Bold" Foreground="Red"/></Canvas>运行后显示效果如下:
@H_419_121@
使用内联样式不是一种很好的做法,样式不可重用,页面XAML代码混乱等,这些缺点其实类似于在HTML中直接设置元素的样式。一种推荐的方式是应该使用全局的样式。 全局样式 为了更好使样式能够重用,并且减少XAML中的代码,推荐使用全局样式。在App.xaml中定义两个样式<Application.Resources> <Style x:Key="button1" targettype="button"> <Setter Property="FontFamily" Value="微软雅黑"></Setter> <Setter Property="FontSize" Value="24"></Setter> <Setter Property="Foreground" Value="Green"></Setter> <Setter Property="Background" Value="Red"></Setter> </Style> <Style x:Key="button2" targettype="button"> <Setter Property="FontFamily" Value="微软雅黑"></Setter> <Setter Property="FontSize" Value="24"></Setter> <Setter Property="Foreground" Value="Red"></Setter> <Setter Property="Background" Value="Red"></Setter> </Style></Application.Resources>通过Style元素指定,需要设置唯一的一个Key,类似于CSS中的类名或者ASP.NET 2.0中Skin功能,并且通过targettype指定该样式将使用在哪类控件上,每一个属性都用Setter来指定。在XAML中,通过StaticResource标记句法来指定具体的样式:
<Canvas Background="#46461F"> <button WIDth="200" Height="60" Canvas.top="90" Canvas.left="30" Content="提 交" Style="{StaticResource button1}"/> <button WIDth="200" Height="60" Canvas.top="90" Canvas.left="260" Content="取 消" Style="{StaticResource button2}"/></Canvas>相比较上面的XAML文件,现在代码已经干净多了,这使得我们可以只专注于应用程序的业务,而无需考虑它的外观(在Beta1中似乎有些属性设置后会报错)。运行后效果如下: 样式重写 定义了全局样式之后,样式能够被重写,即内联样式的优先级高于全局样式。如上面的示例中,我们在XAML中通过属性Foreground指定第一个按钮的前景色为蓝色:
<Canvas Background="#46461F"> <button WIDth="200" Height="60" Canvas.top="90" Canvas.left="30" Content="提 交" Style="{StaticResource button1}" Foreground="Blue" /> <button WIDth="200" Height="60" Canvas.top="90" Canvas.left="260" Content="取 消" Style="{StaticResource button2}"/></Canvas>尽管我们在全局样式中指定第一个按钮的前景色为绿色,通过内联样式重写后,它显示为蓝色: 结束语 本文简单的介绍了Silverlight 2中使用样式来封装控件观感,对任何控件都可以使用全局样式进行封装。
本文出自 “TerryLee技术专栏” 博客,请务必保留此出处http://www.voidcn.com/article/p-vpmmhpqq-wq.html
本文出自 51CTO.COM技术博客 总结以上是内存溢出为你收集整理的(8):Silverlight 2 使用样式封装控件观感全部内容,希望文章能够帮你解决(8):Silverlight 2 使用样式封装控件观感所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)