WPF XAML基础

一、定义

1、XAML:可扩展应用程序标记语言(Extensible Application Markup Language)由微软创造

主要应用于WPF,Silverlight中

2、XAML的发音为"Zamel",继承于XML,和XML一样大小写敏感,注意XAML、XML、HTML的异同点

3、在WPF中,XAML运行在CLR之上,但它不编译为IL,而是编译为BAML,在运行时会被解析成CLR类型

 

二、特点

强类型

微软推荐XAML被编译成BAML(Binary Application Markup Language-二进制语言程序标记语言)。XAML和BAML都可以被WPF解析,并且将以一种和HTML相似的方式进行界面的呈现。但是和HTML不同的是,XAML是强类型化的。也就是说,HTML会忽略那些它不能识别的元素和属性,而XAML必须在识别所有的元素和属性的情况下,才对页面进行呈现。尽管在XAML中各个属性都是以一个个的字符串(例如Background)表示的,但是这些字符串实际上代表的是WPF中的对象,只有被WPF识别的对象才可以作为元素的属性,所以我们说XAML是强类型化的

 

三、XAML语法介绍

1、标签语法=对象元素(Object Elements)

        每个标签即是一个对象元素,将被解析为一个WPF Framework(主要来自PresentationFramework.dll)中的类的实例,类似spring.Net  框架(DC,IOC) 

例:Button

<Button Name="btn1" Content="btn1" Click="btn1_Click" />

 

2、Attribute赋值语法

       2.1 普通字符串赋值。下面代码给Button的Property和Event赋值,字符串将被通过包装好的TypeConverter来转换成对象。

例如Name和Content

      <Button x:Name="btnClick" Content="点我"  Click="btnClick_Click"/>

 

2.2 标记扩展赋值。用花括号这种方式赋值就叫标记扩展赋值。常用的地方是在用到绑定和资源的时候。

       <Button x:Name="btnClick" Content="点我" Command="{Binding Click}" HorizontalAlignment="Left" Margin="212,136,0,0" VerticalAlignment="Top" Width="75" />

 

2.3 属性元素赋值。有的时候简单字符串赋值不了的,就用属性元素赋值。

      <Button x:Name="btnClick1"  Click="btnClick_Click">

            <Button.Content>

                click

            </Button.Content>

     </Button>

 

2.4 内容赋值。控件要有Content这个属性,也就是要继承自ContentControl这个类,才能这么赋值。夹在标签中间。

       <Button>click</Button>

 

2.5 集合赋值。下面例子是给StackPanel.Children这个属性赋值一个集合,被省略了。这个属性的类型是UIElementCollection。在这个例子,我们也看到WPF支持一些省略的写法,可以使XAML代码更简洁。

    <StackPanel>

        <Button>click</Button>

        <Button>click</Button>

   </StackPanel>

 

四、XAML命名空间

     在WPF中一般用在Root元素上(Application,Window,UserControl,Page,ResourceDictionary等)。如下:

       xmlns为引入命名空间的attribute。

      第一行xmlns是没有指定别名的,是默认命名空间,它指定的命名空间包含了微软提供所有的XAML控件的程序集。

       第二、三、四行xmlns别名是x,d,mc,也是微软提供的命名空间,这里面主要包含了一些关于解析Xaml语言的程序集。

       第五行xmlns是自己引入的,开发人员自己写的控件等,可以通过命名空间这种方式引用到XAML文档来使用。

<Window x:Class="WpfApplicationDemo.MainWindow"

        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"

        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"

        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"

        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"

        xmlns:local="clr-namespace:WpfApplicationDemo"

        mc:Ignorable="d"

        Title="MainWindow" Height="350" Width="525">

 

五、附件属性

 

     <StackPanel>

  <Button Panel.ZIndex="1">a</Button>

  <Button Panel.ZIndex="2">b</Button>

    </StackPanel>

 Panel.ZIndex就是附加属性,而附加事件在界面上用不了。在后面具体实现项目时在来写附加事件

 

总结:

WPF通过一个 partial 关键字,将一个类的定义切分为两部分:XAML和Code-Behind。

其中XAML交给设计师设计,Code-Behind交给程序员写业务逻辑,从而实现分离(虽然大部分时候全部都是程序员完成的)。

我们在XAML上写标签,其实与后台写代码是等效的。只要你想,完全可以只使用XAML或者只是用Code-Behind来写程序。

注意: XAML中x:Name和Name最终效果相同

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值