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

概述

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,我们添加了两个按钮,并在其中设置字体的样式:

<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>

运行后显示效果如下:

TerryLee_Silverlight2_0042

使用内联样式不是一种很好的做法,样式不可重用,页面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中似乎有些属性设置后会报错)。运行后效果如下:

TerryLee_Silverlight2_0043

样式重写

定义了全局样式之后,样式能够被重写,即内联样式的优先级高于全局样式。如上面的示例中,我们在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>

尽管我们在全局样式中指定第一个按钮的前景色为绿色,通过内联样式重写后,它显示为蓝色:

TerryLee_Silverlight2_0044

结束语

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

下一篇:一步一步学Silverlight 2系列(9):使用控件模板

作者:TerryLee
出处:http://terrylee.cnblogs.com
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
Tag标签: Silverlight,XAML
posted @ 2008-03-08 14:13 TerryLee 阅读(7427) 评论(31)  编辑 收藏 网摘 所属分类: [03]  银光点亮世界

  回复  引用  查看    
#1楼 2008-03-08 15:00 | 王德水      
去抽根烟,估计回来可以看下一篇了,呵呵,TerryLee大侠速度真快,快赶上Scotte了,加油
  回复  引用  查看    
#2楼 [楼主]2008-03-08 15:05 | TerryLee      
@王德水
我可不敢跟ScottGu相比,写累了,现在休息一下,呵呵:)
  回复  引用    
#3楼 2008-03-08 15:25 | neo08 [未注册用户]
好像silverlight 2.0没有System.Data 类库,那怎么从数据库读数据呢?能写个demo吗?谢谢
  回复  引用  查看    
#4楼 [楼主]2008-03-08 15:36 | TerryLee      
@neo08
在后面会写到。。。
  回复  引用    
#5楼 2008-03-08 16:51 | 5254341 [未注册用户]
很好,很强大。值得研究
  回复  引用    
#6楼 2008-03-08 16:56 | 5254341 [未注册用户]
TerryLee 老大我拜你为师吧!太牛了
  回复  引用  查看    
#7楼 [楼主]2008-03-08 17:06 | TerryLee      
@5254341
Silverlight 2确实功能增强了不少

太客气了,大家互相交流吧:)

  回复  引用  查看    
#8楼 2008-03-20 10:51 | 张荣华      
哈 学习中
有点遗憾的是VS对Silverlight的支持不是很好,比如在Xaml文件中手动录入一个控件后,如果不点击保存按钮,在后台类中直接用this.,是不会出现刚添加的控件的。
再比如当Xaml文件中有错误时,VS提示的信息对修改帮助也不大。

  回复  引用  查看    
#9楼 [楼主]2008-03-20 10:55 | TerryLee      
@张荣华
现在还是Beta 1,等正式版发布以后,可能会有所改善:)
  回复  引用    
#10楼 2008-04-10 13:04 | jazz [未注册用户]
楼主,你好,我在做全局样式示例时,在app.xaml里面定义了样式以后在page.xaml里面应用

可以当我运行时出现下面错误
“A first chance exception of type 'System.Windows.Markup.XamlParseException' occurred in System.Windows.dll

Additional information: System.Exception: Catastrophic failure (Exception from HRESULT: 0x8000FFFF (E_UNEXPECTED))
at MS.Internal.XcpImports.ConvertStringToTypedCValue(IntPtr pContext, UInt32 cClrTypeName, String clrTypeName, UInt32 cValue, String value, CValue& outVal, Int32& typeIndex)
at MS.Internal.SilverlightTypeConverter.ConvertFrom(Object value) [Line: 0 Position: 2]

这是怎么回事?
  回复  引用  查看    
#11楼 2008-06-17 23:21 | 房客      
请问一下,
silverlight sdk在哪里有下载?
在本地MSDN中好像不包含有silverlight的介绍
  回复  引用  查看    
#12楼 2008-07-15 22:23 | qianbao      
飘过。。学习了

谢谢LZ

。。感谢
  回复  引用  查看    
#13楼 [楼主]2008-07-21 10:24 | TerryLee      
@jazz
可能你在样式中某个地方有错误,由于现在对于XAML的检查比较弱,大多数时候都会编译成功,你要仔细的检查样式,如看有没有丢掉<或者>之类的标记。
  回复  引用  查看    
#14楼 [楼主]2008-07-21 10:25 | TerryLee      
@房客
代震军的一篇文章有过介绍,你搜一下就有了。。
  回复  引用  查看    
#15楼 [楼主]2008-07-21 10:25 | TerryLee      
@qianbao
:)
  回复  引用  查看    
#16楼 2008-08-18 22:59 | Kai.Ma      
最开始的是内嵌样式吧,跟html的内联可不同。内联是放在head区的。
  回复  引用  查看    
#17楼 [楼主]2008-08-20 10:20 | TerryLee      
@Kai.Ma
其实在Silverlight中根本没有内联或者内嵌样式这么一说,这里仅仅是为了跟全局样式等进行区分。。。
  回复  引用    
#18楼 2008-09-05 10:50 | warren guo [未注册用户]
Silverlight 2 b 2的style好像不支持BaseOn?
  回复  引用    
#19楼 2008-11-20 21:08 | yiyihui [未注册用户]
请教LZ 现在的Silverlight版本不同,导致示例的使用方法行不同了,不知道现在这个版本如何使用Style
<Button x:Name="styleBtn" Width="50" Height="50" Canvas.Left="150" Canvas.Top="150" Content="提交" Style="{StaticResource button1}"></Button>
<Canvas.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>
</Canvas.Resources>

运行时报错:找不到style="button1"
  回复  引用    
#20楼 2008-11-20 21:21 | yiyihui [未注册用户]
还有一个问题麻烦楼主:
就是我添加了Image 然后添加一个图片放在Bin文件夹,引入到工程,但是通过Source="图片.jpg" 不能正常显示图片,不知道为什么?
先谢谢楼主了!
  回复  引用  查看    
#21楼 [楼主]2008-11-20 23:48 | TerryLee      
@yiyihui
1. 现在仍然可以这么使用,我不确定这个问题是由什么引起的。

2. 图片路径问题,你可以放在跟Xaml统一目录下试试看
  回复  引用    
#22楼 2008-11-22 21:38 | yiyihui [未注册用户]
感谢楼主问题已经解决!
另问一下楼主:你说有可能使用这个Silverlight做个控件吗?类似Vc的Com组件?
  回复  引用  查看    
#23楼 [楼主]2008-11-24 09:55 | TerryLee      
@yiyihui
做个控件想在哪儿用?

标题  
姓名  
主页
Email (博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
该文被作者在 2008-03-08 17:12 编辑过
Google站内搜索



相关文章:


相关搜索:
Silverlight XAML

相关链接: