WP7开发学习(4):Style样式的四种使用

本文深入探讨了在WP7应用开发中使用CSS样式的三种常见方法:内联样式、嵌入样式和外联样式。详细解释了每种方法的操作步骤、优缺点及应用场景,帮助开发者更好地理解和应用样式设置。

Web开发中,我们通过CSS来控制页面元素的样式,一般常用三种方式:

1. 内联样式表:即直接设置元素的style属性

2. 嵌入样式表:即在html页面上写一个<style>……..</style> 代码段,然后设置元素的class 属性

3. 外部样式表:即写一个独立的.css 文件,然后再html页面上引入该文件,然后设置元素的class属性

 

具体如何操作,这里就不说了。不懂的去百度一把,绝对会出现一大坨。

同样的,在WP7开发中,也有类似以上几种方式设置控件的样式——开发平台可以千差万别,编程思想都是大同小异的。

 

一,内联样式:

直接设置控件的 Height WidthForegroundHorizontalAlignmentVerticalAlignment 等属性。以设置一个Botton控件的样式为例,如:

复制代码
< Grid x:Name ="ContentPanel" >
< Button Content ="Button" Name ="btnDemo"
Height
="72"
Width
="150"
Foreground
="White"
Background
="Blue"
HorizontalAlignment
="Left"
VerticalAlignment
="Top"
Margin
="170,132,0,0"
Grid.Row
="1" />
</ Grid >
复制代码

这种方式比较简单,但是代码不能复用。

 

二,嵌入样式:

在页面<phone:PhoneApplicationPage.Resources> 节点下添加样式,然后在需要的控件上设置Style 属性。还是以上面那个Botton控件为例。

1,在页面<phone:PhoneApplicationPage.Resources>节点下添加一个Key值叫“BtnStyle”的样式

复制代码
< phone:PhoneApplicationPage.Resources >
< Style x:Key ="BtnStyle" TargetType ="Button" >
< Setter Property ="Height" Value ="72" />
< Setter Property ="Width" Value ="150" />
< Setter Property ="Foreground" Value ="White" />
< Setter Property ="Background" Value ="Blue" />
< Setter Property ="HorizontalAlignment" Value ="Left" />
< Setter Property ="VerticalAlignment" Value ="Top" />
</ Style >
</ phone:PhoneApplicationPage.Resources >
复制代码
2, 设置 Botton 控件的 Style 属性为 "{StaticResource BtnStyle}"
< Grid x:Name ="ContentPanel" >
< Button Content ="Button" Name ="btnDemo"
Style
=" {StaticResource BtnStyle} "
Margin
="170,132,0,0" />
</ Grid >

 

解释一下,TargetType="Button" 指定了该样式适用于Botton类型的控件Key="BtnStyle" 如果不设置该值,则该样式将适用于所有的Botton 控件,而设置了其值为“BtnStyle,则只用于设置了 Style="{StaticResource BtnStyle}" Botton控件。这就好比CSS中的元素选择器和类选择器。


这种方式可以使得单个页面上的控件能够复用一个样式,比第一种方式面向对象了一步。

三,外联样式:

1,新建一个.xaml资源文件,/Resources/BtnStyle.xaml

2, BtnStyle.xaml文件里编写样式代码

复制代码
BtnStyle.xaml:
< ResourceDictionary
xmlns ="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x
="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:System
="clr-namespace:System;assembly=mscorlib" >
< Style x:Key ="BtnStyle" TargetType ="Button" >
< Setter Property ="Height" Value ="72" />
< Setter Property ="Width" Value ="150" />
< Setter Property ="Foreground" Value ="White" />
< Setter Property ="Background" Value ="Blue" />
< Setter Property ="HorizontalAlignment" Value ="Left" />
< Setter Property ="VerticalAlignment" Value ="Top" />
</ Style >
</ ResourceDictionary >
复制代码


3,在App.xaml文件的<Application.Resources>

或者普通页面的<phone:PhoneApplicationPage.Resources>

或者用户控件的 <UserControl.Resources> 节点下

添加相应的ResourceDictionary,配置引用BtnStyle.xaml:

复制代码
app.xaml:
< Application.Resources >

< ResourceDictionary >
< ResourceDictionary.MergedDictionaries >
< ResourceDictionary Source ="Resources/BtnStyle.xaml" />
<!-- <ResourceDictionary Source="Resources/BtnStyle2.xaml"/>
<ResourceDictionary Source="Resources/BtnStyle3.xaml"/>
-->
</ ResourceDictionary.MergedDictionaries >
</ ResourceDictionary >

</ Application.Resources >
或者MainPage.xaml:
< phone:PhoneApplicationPage.Resources >

< ResourceDictionary >
< ResourceDictionary.MergedDictionaries >
< ResourceDictionary Source ="Resources/BtnStyle.xaml" />
</ ResourceDictionary.MergedDictionaries >
</ ResourceDictionary >

</ phone:PhoneApplicationPage.Resources >
复制代码

<ResourceDictionary.MergedDictionaries>节点下可以添加多个资源文件

这种方式相比前面两种使得样式和结构又更进一步分离了。

App.xam引用,是全局的,可以使得一个样式可以在整个应用程序中能够复用。在普通页面中引用只能在当前页面上得到复用。


4,
设置Botton 控件的Style 属性为"{StaticResource BtnStyle}" 和上面的一样。

 

四,用C#代码动态加载资源文件并设置样式

1,新建资源文件:同上面的12两步。

2,在后台编写代码

ResourceDictionary resourceDictionary = new ResourceDictionary();

Application.LoadComponent(resourceDictionary, new Uri("/PhoneApp1;component/Resources/BtnStyle.xaml", UriKind.Relative));
Application.Current.Resources.MergedDictionaries.Add(resourceDictionary);
//以上几行代码表示将我们自定义的样式加载到应用程序的资源字典中。
this.btnDemo.SetValue(Button.StyleProperty, Application.Current.Resources["BtnStyle"]);


原文地址: http://www.cnblogs.com/xumingxiang/archive/2012/03/23/2413342.html

转载于:https://www.cnblogs.com/zziss/archive/2012/11/07/2758917.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值