.NEt专家博客!

【李会军】一步一步学Silverlight 2系列(8):使用样式封装控件观感

上一篇 / 下一篇  2008-04-11 19:27:49

概述

Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, Ironpython,对JSON、Web Service、WCF以及Sockets的支持等一系列新的特性。《一步一步学Silverlight 2系列》文章带您快速进入Silverlight 2开发。

本文为系列文章第八篇,主要介绍在Silverlight中使用Style元素封装控件观感

Silverlight 支持一种 Style. 机制,它允许我们把控件的属性值封装成可重用的资源。我们可以把这些样式声明保存在独立于页面的其他文件中,然后就可以在一个应用程序中跨控件和页面重用 (甚至跨多个应用程序重用)。在做一些基本定制的场景下,概念上类似于在 HTML 中重用 CSS。

内联样式

内联样式这个概念其实跟我们在HTML中指定元素的样式一样,在XAML中通过属性来设置,如下面这段XAML,我们添加了两个按钮,并在其中设置字体的样式:

<CanvasBackground="#46461F">
H6~*E5z4f3o0<
ButtonWidth="200"Height="60"Background="Red"
$c6~3PA4y`U0
Canvas.Top="90"Canvas.Left="30"Content="提 交"ITPUB个人空间-V$nv;EO:H2d
FontFamily="微软雅黑"ITPUB个人空间.eUik^Y;]Y}
FontSize="24"ITPUB个人空间,b4i{8a/b ao|
FontWeight="Bold"
4dW"]Xm+~&{0
Foreground="Green"/>ITPUB个人空间8qzy`#\g

@9XZ"Un$c&mE,\Z y]0<
ButtonWidth="200"Height="60"Background="Red"ITPUB个人空间HG*F#d}n
Canvas.Top="90"Canvas.Left="260"Content="取 消"
? c+I[W2kR.Jgl0
FontFamily="微软雅黑"ITPUB个人空间z5LM(hZ+Y"}
FontSize="24"ITPUB个人空间-p8z:d-g9K-c jm1T+g
FontWeight="Bold"ITPUB个人空间J$f5]VYUl&yge3Z
Foreground="Red"/>
!{*^4E*jkC9dj'n0</
Canvas>

运行后显示效果如下:
Q*FH(ed&R0
1F%U)u%Q+a xVI]R0

使用内联样式不是一种很好的做法,样式不可重用,页面XAML代码混乱等,这些缺点其实类似于在HTML中直接设置元素的样式。一种推荐的方式是应该使用全局的样式。

全局样式

为了更好使样式能够重用,并且减少XAML中的代码,推荐使用全局样式。在App.xaml中定义两个样式

<Application.Resources>
%sH/U^? BM\ v0<
Style.x:Key="button1"TargetType="Button">
~o!@s G0<
SetterProperty="FontFamily"Value="微软雅黑"></Setter>ITPUB个人空间5t%uv&F%^ l]
<
SetterProperty="FontSize"Value="24"></Setter>
qmg;|w0<
SetterProperty="Foreground"Value="Green"></Setter>
r]s KWfbla7S0<
SetterProperty="Background"Value="Red"></Setter>
1hL;P|s4M2{Y3a`0</
Style>ITPUB个人空间']f%Wg G O"M&OC O?
<
Style.x:Key="button2"TargetType="Button">ITPUB个人空间6q7a2H} v9\}"`
<
SetterProperty="FontFamily"Value="微软雅黑"></Setter>
nN{dA'\Yk0<
SetterProperty="FontSize"Value="24"></Setter>ITPUB个人空间xD9vO PH,q VX.X
<
SetterProperty="Foreground"Value="Red"></Setter>ITPUB个人空间-w^2U#p D#w1r Fj
<
SetterProperty="Background"Value="Red"></Setter>ITPUB个人空间3`'w2Mr%PI?+f f3@ H
</
Style>ITPUB个人空间 PV"l'p5@C qR
</
Application.Resources>

通过Style元素指定,需要设置唯一的一个 Key,类似于CSS中的类名或者ASP.NET 2.0中Skin功能,并且通过TargetType指定该样式将使用在哪类控件上,每一个属性都用Setter来指定。在XAML中,通过 StaticResource标记句法来指定具体的样式:

<CanvasBackground="#46461F">
/h;w UTd)gd+]0<
ButtonWidth="200"Height="60"
g5[#v g)Q5~v:r4ho9q0
Canvas.Top="90"Canvas.Left="30"Content="提 交"ITPUB个人空间0\1k b7X {8I?
Style="{StaticResourcebutton1}"/>ITPUB个人空间k S*fG9^0G `
ITPUB个人空间 m+kEusj8g`
<
ButtonWidth="200"Height="60"
0K/io!Bfpr0
Canvas.Top="90"Canvas.Left="260"Content="取 消"
5i-j8d9t6y0
Style="{StaticResourcebutton2}"/>ITPUB个人空间Y*~#^#S8b
</
Canvas>

相比较上面的XAML文件,现在代码已经干净多了,这使得我们可以只专注于应用程序的业务,而无需考虑它的外观(在Beta1中似乎有些属性设置后会报错)。运行后效果如下:
Oy P)U3H$uJ8\L z0
#{P/q"xhA-h+W'|0

样式重写

定义了全局样式之后,样式能够被重写,即内联样式的优先级高于全局样式。如上面的示例中,我们在XAML中通过属性Foreground指定第一个按钮的前景色为蓝色:

<CanvasBackground="#46461F">
|Q]F j^0<
ButtonWidth="200"Height="60"ITPUB个人空间)_/i-f!I J%@
Canvas.Top="90"Canvas.Left="30"Content="提 交"
7M},e!?"A$[oI8a3l.U6z0
Style="{StaticResourcebutton1}"ITPUB个人空间d{7c,Fbh bB/l
Foreground="Blue"
(dU}(B*[,N0/>
5k9u|+_!Q[ UKY4UUC.V0
QS XE5p e2s0<
ButtonWidth="200"Height="60"ITPUB个人空间 u1Fj"Aj
Canvas.Top="90"Canvas.Left="260"Content="取 消"
(Xu3JfN-p_'~0
Style="{StaticResourcebutton2}"/>
5c9V1h@q7T5_ y0</
Canvas>

尽管我们在全局样式中指定第一个按钮的前景色为绿色,通过内联样式重写后,它显示为蓝色:
"h-YK ~L;T0ITPUB个人空间J s3Sw#J @+t$`!O

结束语

本文简单的介绍了Silverlight 2中使用样式来封装控件观感,对任何控件都可以使用全局样式进行封装。

作者:TerryLeeITPUB个人空间9^8@g [-K x p$y
出处:http://terrylee.cnblogs.com


rj*Q lH(B#J+@ F0


TAG:

引用 删除 Guest   /   2009-04-26 01:20:23
3
 

评分:0

我来说两句

显示全部

:loveliness: :handshake :victory: :funk: :time: :kiss: :call: :hug: :lol :'( :Q :L ;P :$ :P :o :@ :D :( :)

Open Toolbar