Wpf基础入门——XAML篇
本篇文章学习于: 刘铁猛老师《深入浅出WPF》
什么是“项目模板”?
最简单的WPF程序
App.xaml
MainWindow.xaml
MainWindows.cs
浅析用户界面的树型结构
示例:
在XAML中为对象属性赋值
Attribute=Value形式
例如:【不能设置太复杂的值】
可以注意到在xaml文件中设置的value都是string类型,但在实际中是其他类型。
实质如下:
属性标签
示例:【可以设置太复杂的值,但是代码变长了】
建议:这边建议能使用Attribute=Value的形式写Attribute=Value,不能的话用这个;如果要这么写的值是默认值的话就不要写出来了。
标签扩展
StaticResource
Bind
事件处理器与代码后置
事件模型
例如:
Button ——事件的拥有者
Click ——点击事件
void Button_Click(object s,RoutedEventArgs e){ MessageBox.Show("Hello WPF!"); } ——事件处理器
窗体 ——事件的响应者
事件订阅 —— Click="Button_Click"【XAML】 或者
this.Button.Click+=newRoutedEventHandler(Button_CLick)【CS】
导入程序集和引用其中的命名空间
示例:
(1)创建一个程序集【build】
(2)引用,然后添加命名空间:
xmlns:con="clr-namespace:MyWpfControlLibrary;assembly=MyWpfControlLibrary"
就可以使用这个命名空间下的类了
<con:SalaryCalcuator />
XAML的注释
<!-- -->
<!--
-->
x名称空间的由来和作用
x名称空间的声明:x是xaml的缩称,用来解析和分析xaml代码的。也叫xaml名称空间
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
x名称的使用:使用x名称空间下Class这个元素
例如:x:Class="MyWpfApp.MainWindow"
x名称空间里都有些什么?
x名称空间里的Attribute
x:Class
使用x名称空间下Class这个元素,使得xaml文件生成的类与MyWpfApp.MainWindow这个类合并
x:Class="MyWpfApp.MainWindow"
x:ClassModifier
类的访问级别【默认是public】 x:ClassModifier="public"
注意:xaml文件设置修改了,对应的cs文件也要修改类的访问级别
x:Name
(1)为xaml文件生成的这个实例创建引用变量
例如: <Button x:Name:"button1"/>,这样就可以在cs代码使用button1去访问这个Button实例
(2)看这个实例有没有Name属性,如果有Name这个属性的话,同时用变量的名字给Name属性赋值
例如:Messagebox.Show(button1.Name);
x:FieldModifier
类中成员变量(字段)的访问级别
例如:
<Button x:FieldModifier="private" Height="100" Width="200"/>
,这样在其他类就不能访问这个Button实例了。
x:Key
在XAML文件中,我们可以把很多需要多次使用的内容提取出来放在资源字典(Resource Dictionary)里,需要使用这个资源的时候就用它的Key把它检索出来。
x:Key的作用就是为资源贴上用于检索的索引。
示例:
资源也可以在C#中访问
x:Shared
x:Shared 一定要与x:Key配合使用, 如果x:Shared的值为true,那么每次检索到这个对象时,我们得到的都是同一个对象;否则如果x:Shared的值为false,每次我们检索到这个对象时,我们得到的都是这个对象的一个新副本。XAML编译器会为资源隐藏地添加x:Shared="true",也就是说,默认情况下我们得到的都是同一个对象。
x命名空间中的标记扩展
x:Type
标记扩展(Markup Extension)实际上就是一些MarkupExtension 类的直接或间接派生类。x名称空间中就包含有一些这样的类,所以常称它们为x名称空间内的标记扩展。
x:Type的值应该是一个数据类型的名称。一般情况下,我们在编程中操作的是数据类型的实例或者是实例的引用,但有时候我们也会用到数据类型本身。
当我们在XAML中想表达某个数据类型时就需要使用x:Type标记扩展。比如某个类的一个属性,它的值要求是一种数据类型,当我们在XAML为这个属性赋值时就要使用x:Type。
x:Null
在XAML里用来表示空值的是x:Null。让我们来看一个例子。
大多数时候我们不用显式地为一个属性赋null值,但如果一个属性具有默认值而我们又不需要这个默认值时就需要显式地设置null值了。在WPF 中,Style 的作用是按照一定的审美规格设置控件的各个属性,程序员可以通过为控件更换Style来产生各种风格迥异的效果。程序员可以逐个为控件设置Style,也可以为一个Style指定目标控件类型,一旦指定了目标类型那么这类控件的实例将都使用这个Style——除非你显式地将某个实例的Style属性设置为x:Null。
<Window x:Class="WpfAppiication 1. Window 1"
xmlns="http://schemas.microsoft.com/winfic/2006/xaml/presentationN
xmlns:x="http://schemas.microsoft.com/winfx/2006/xamr,
Title="x:Nuli Sample" Height="3OO" Width="3OO">
<Window.Resources>
<Style x:Key="{x:Type Button}" TargetType="{x:Type Button}">
<Sctter Property3" Width" Value="60"/>
<Setter Property="Height" Value="367>
<Setter Property="Margin,' Value="5"/>
</Style>
</Window.Resources>
<StackPanel>
<Button Content="OK"/>
<Button Content="OK"/>
<Button Content="OK"/>
<Button Content="OK" Style="{x:Null}">
</StackPanel>
</Window>
上面的例子把一个Style 放在了 Window 的资源里并把它的x : Key 和TargetType 都设置成了Button 类型,这样,UI上的所有Button控件都会默认地被套用这个Style——除了最后一个Button——因为它显式地把Style设置为了 x:Null。
标记扩展实例的两种声明语法
<Button Content="OK">
<Button.Style>
<x:Null/>
</Button.Style>
</Button>
这样做的缺点显而易见,就是代码太啰嗦。所以,为了保持代码的简洁,我们很少使用这种语法。但有一个例外,那就是x : Array 标记扩展一如果想在XAML文档里声明一个包含数据的x:Array实例,必须使用标签式声明才能做到。
x:Array
x:Array的作用就是通过它的Items属性向使用者暴露一个类型己知的ArrayList实例,ArrayList内成员的类型由x:Array 的Type 指明。
下面这个例子是把一个x:Array 当作数据源向一个ListBox提供数据。在WPF 中把包含数据的对象称为数据源(DataSource) 。如果想把一个x:Array 的实例作为数据源提供给一个ListBox的话:
<ListBox Margin="5">
<ListBox.ItemsSource>
<x:Array type="sys:String">
<sys:String>Tim</sys:String>
<sys:String>Tom</sys:String>
<sys:String>Victor</sys:String>
</x:Array>
</ListBox.ItemsSource>
</ListBox>
x:Static
x:Static是一个很常用的标记扩展,它的功能是在XAML文档中使用数据类型的static成员。 因为XAML不能编写逻辑代码,所以使用x:Static访问的static成员一定是数据类型的属性或字段。
示例:
首先,为Windowl添加两个static成员,一个是static字段,一个是static属性。
然后,在XAML中使用x:Static来访问这两个成员:
XAML指令元素
XAML指令元素只有两个
- x:Code
- x:XData
我们已经在代码后置一节介绍过<x:Code>标签,它的作用就是可以包含一些本应放置在后置代码中的C#代码。这样做的好处是不用把XAML代码和C#代码分罝在两个文件中,但若不是遇到某些极端环境我想应该没人这么干,这样做最大的问题就代码不好维护、不易调试。
x:XData标签是一个专用标签。WPF中把包含数据的对象称为数据源,用于把数据源中的数据提供给数据使用者的对象被称为数据提供者(Data Provider)。WPF类库中包含多种数据提供者,其中有一个类叫XmlDataProvider,专门用于提供XML化的数据。如果想在XAML里声明一个带有数据的XmlDataProvider实例,那么XmlDataProvider实例的数据就要放在x:XData标签的内容里。
<Window.Resourccs>
<XmlDataProvider x:Key="lnventoryData" XPath="Inventory/Books">
<x:XData>
<Supermarket xmlns="">
<Fruits>
<Fruit Name="Peach"/>
<Fruit Name="Banana">
<Fruit Name="Orange">
</Fruits>
<Drinks>
<Drink Name="Coca Cola"/>
<Drink Name="HPEPSI Cola"/>
</Drinks>
</Supermarket>
</x:XData>
</XmlDataProvider>
</Window.Resources>