天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

一步一步學Silverlight :使用樣式封裝控件觀感

概述

Silverlight 2 Beta 1版本發布了,無論從Runtime還是Tools都給我們帶來了很多的驚喜,如支持框架語言Visual Basic, Visual C#, IronRuby, IronPython,對JSON、Web Service、WCF以及Sockets的支持等一系列新的特性?!兑徊揭徊綄WSilverlight 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中使用樣式來封裝控件觀感,對任何控件都可以使用全局樣式進行封裝。

NET技術一步一步學Silverlight :使用樣式封裝控件觀感,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 日日噜噜夜夜狠狠视频 | 快播官方网站 | 国产免费久久爱久久啪 | 亚洲 天堂 国产在线播放 | 小草观看免费高清视频 | 五月丁香婷姐色 | 色婷婷国产精品视频一区二区 | 呻吟翘臀后进爆白浆 | abp-146| 国产又粗又猛又爽又黄的免费视频 | 精品欧美一区二区三区久久久 | 各种场合肉H校园1V1 | 国产精品国产三级国AV在线观看 | 久久视热频这里只精品 | 亚洲一日韩欧美中文字幕在线 | 任你躁精品一区二区三区 | 亚洲AV 中文字幕 国产 欧美 | 中文字幕亚洲乱码熟女在线 | 欧美 亚洲 中文字幕 高清 | 亚洲精品乱码8久久久久久日本 | 麻豆国产96在线日韩麻豆 | 国产成人AV永久免费观看 | 九九热视频这里只有精 | 成年人在线视频免费观看 | 久久九九有精品国产23百花影院 | 亚洲精品资源网在线观看 | 青春草久久 | 搡女人免费免费视频观看 | 亚洲欧美精品一中文字幕 | 国产精品国产三级国AV在线观看 | MELODY在线播放无删减 | 欧美日韩无套内射另类 | 和I儿媳妇激情 | 久久一级片 | 亚洲欧美免费无码专区 | 国产午夜精品一区理论片飘花 | 亚洲国产精品嫩草影院久久 | 日韩av片无码一区二区不卡电影 | 国产高清视频在线观看97 | 百性阁论坛首页 | 2020年国产精品午夜福利在线观看 |