zoukankan      html  css  js  c++  java
  • 04.移动先行之谁主沉浮----XAML的探索

    如果移动方向有任何问题请参考===> 异常处理汇总-移动系列(点)

    移动先行之谁主沉浮? 带着你的Net飞奔吧! 链接======>(点)

    XMAL引入

    XAML 类似于 HTML,是一种特殊的XML语言

    XAML本质上属于一种.NET Programming Language

    主要应用在 Windows 8、Windows Phone、Silverlight 和 WPF 中

    1.XMAL 命名空间的声明

    分析一下头文件

    详细注解

    在属性里面改过名字后就会以x:开头

    补充:xmlns(XML Namespace)默认命名空间==>xmlns不是XAML中特有或特别定义的,它是XML具备的,目的是为了约束XML的文档结构xmlns:d 和 xmlsn:ms 是为 Visual Studio 设计视图服务的,不会对程序造成任何影响

    2.XAML 创建对象元素

    1.标签名即控件名称

    2.一个 XAML 文件只允许有一个根对象元素 Page(类似于xml根节点


    3.标签属性或子标签为控件对象属性操作


    4.每个 XAML 标签都会有一个相对应的类型


    5.每声明一个 XAML 节点就相当于创建相应类型的对象
    6.在哪个元素结点下添加标签就相当在哪个对象下添加对象

    3.XAML 设置元素对象属性(四种语法)

      1.键值语法:依靠内置转换器去实现(可以是文本块,按钮内容,背景图片等)
        属性键值语法,即 PropName=“PropValue”;
        绝大多数属性都是使用属性键值的形式来操作;
        要求属性类型必须为一些“简单的/可以自动转换的”类型(解释转换器带来的效果)

      比如:水平对齐方式应该是枚举类型

      

      但,键值语法给他赋值的是字符串,同样能达到效果====>可以自动转换(内置属性类型转换器

      

      补充:

        只有实例化对象才可以设置实例属性,格式如下:

          <objectName propertyName=“propertyValue”/>

          或者

          <objectName propertyName=“propertyValue”>

          </objectName>

      每个属性对应一个属性值,属性值类型必须与属性匹配

      一个标记中可以设置对象的多个属性

      objectName是要实例化的对象,propertyName是需要设置的属性名称,propertyValue是属性的值

      比如:

      


      2.属性元素语法;文本块值,按钮内容,背景图片    

      某些属性可以使用属性元素语法来设置,格式为:

        <object>

            <object.property>

                <!—元素属性值-->

            </object.property>

          </object>

      如果一个对象的属性是一个复杂类型,不能够由简单的字符串直接表示的时候,这时需要用到属性元素的语法:

      <标签名>

          <标签名.属性名>

              <属性值/>

          </标签名.属性名>

      </标签名>

      文本块值,按钮内容,背景图片

    比如:

      

    效果:

      


      3.默认属性语法:只是方便,语法糖(看特性标签秒懂)
        默认属性语法;只是方便语法糖
        对于大多数对象元素都有一个默认属性;
        直接将元素的 “InnerText” 设置为属性值:
        例如:
        <Button x:Name="btn1" Content="Hello"/>
        <Button x:Name="btn2">
          World
        </Button>
        通过特性标签知道默认属性

    同样的可以看一下Grid(类似于表格)的默认属性(进父类)==>Children

    那么完整写法就是:(当然了,我们平时写是没有必要的,这边只是探索一下本质)

    同样的,我们可以反推==>(刚才正推,现在反推)因为Button有一个默认属性是Content,

    那么,我们是不是可以用下面这个写法呢?(事实证明正确

    写法一:<Button><x:String>羊毛头</x:String></Button>

    写法二:<Button>羊毛头</Button>

    其实里面还是可以放图标之类的,这里就不详解了,来两个图,你们自己练练吧


      4.隐式集合语法
      元素支持一个属性元素的集合,才使用集合语法进行设置属性

      使用托管代码的Add方法来增加更多的集合元素

      本质是向对象的集合中添加属性项

      在此之前我们考虑的都是非集合性质的属性;

      对于一个集合类的属性可以用重复子元素的方式实现设置值:

        <Grid>
          <Grid.Children>
            <TextBlock>Hello1</TextBlock>
            <TextBlock>Hello2</TextBlock>
            <TextBlock>Hello3</TextBlock>
            <TextBlock>Hello4</TextBlock>
            <TextBlock>Hello5</TextBlock>
          </Grid.Children>
        </Grid>

      不同的属性类型我们可以选择不同的设置方式;
        简单类型数据,比如字符串、数字之类的使用键值形式;
        复杂类型数据,比如背景图片使用属性元素形式;
        集合性质使用集合语法;

     4.名称范围 (x:) 属性

    X:Class

    配置 XAML 编译,在标记和代码隐藏之间连接分部类。代码分部类在一个独立的代码文件中定义,标记分部类由代码是由 XAML 在编译过程间创建。
    <object
    x:Class="namespace.classname"...>
    ...
    </object>

    x:FieldModifier

     修改 XAML 编译行为,使指定对象引用的字段被定义有 public 访问权限而不是默认的 private 行为。

    语法:
    <object
    x:FieldModifier="public"
    ... />

    x:Key
    唯一标识作为资源被创建和引用的元素,这些资源存在于一个 ResourceDictionary 中。
    XAML 属性使用方法:
    <ResourceDictionary>
    <object x:Key="stringKeyValue".../>
    </ResourceDictionary>
    隐式 ResourceDictionary 中使用:
    <object.Resources>
    <object x:Key="stringKeyValue".../>
    </object.Resources>

    x:Name
    唯一标识对象元素,可方便从代码隐藏或一般代码中访问已实例化的对象。应用于支持的编程模型之后,
    x:Name 可视为等效于持有一个对象引用(由一个构造函数返回)的变量。
    就相当于给对象栓条绳子,方便代码访问
    x:Key 和 x:Name 不是相同的概念。
    x:Key 仅用于资源词典中。
    x:Name 用于 XAML 的所有区域。一个使用键值的 FindName 调用不会检索键资源。

    x:Uid

    为标记元素提供一个唯一标识符。对于 Windows 运行时 XAML,这个唯一标识符供 XAML 本地化过程和工具使用。
    例如,使用 .resw 资源文件中的资源。
    <Button
    x:Uid="ResourceKey"
    Content="被资源中键为“ResourceKey.Content的值替换”"/>
    开发多语言化系统时会经常用到

    其他 XAML 固有数据类型就是常见的简单数据类型的声明

     

    5.XAML 标记扩展

      可扩展基本 XAML 语言特性的 Windows 运行时 XAML 结构

      

    1.Binding:

    像我们平时经常用一些自定义类,在XAML里面怎么弄呢? 这里就用到了Binding了

    先看一个网络插图:(不要懂,你看箭头部分就好)

    ============================

    写法如下:详细看图

    效果

    2.我们再把下面两个说一下,其他的下面的文章里面会慢慢带入的

    StaticResource 不会实时监视系统主题而跟着变化
    ThemeResource 会实时监视系统主题而跟着变化(一般都是一些跟颜色相关的用这个,像字符串之类的就没必要了)

    举个例子:

    demo搭建ing

     

    ===================================================================

    扩展:

    XAML解析案例:

    OnNavigatedTo新页面准备的时候(重写 OnNavigatedTo 方法以检查导航请求并且准备供显示的页面。这个方法就像是初始化(Ini) ,它先于Loaded事件之前被执行,所以在这里可以控制一些初始化前的操作,或初始化的操作。OnNavigatedTo 方法,是在每次页面成为活动(第一次打开时)页面时调用该方法。Silverlight 框架在每次将元素添加到可视化树时引发 Loaded 事件,在激活某一页面时该事件可能会多次发生。)

    OnNavigatedFrom当页面成为非活动的时候 的事件

    Grid定义由行和列组成的灵活的网格区域。Grid 的子元素根据其行/列分配(使用 Grid.Row 和 Grid.Column 附加属性来设置)和其他逻辑进行测量和排列。

    参考:

    http://www.bubuko.com/infodetail-903282.html

    https://msdn.microsoft.com/zh-cn/library/hh758292.aspx

    http://www.cnblogs.com/Jax/archive/2008/04/15/1155135.html

    http://blog.csdn.net/c979170768/article/details/7017014

    https://msdn.microsoft.com/zh-cn/library/windows/apps/hh700354.aspx

  • 相关阅读:
    centos7.6 安装与配置 MongoDB yum方式
    MongoDB 介绍
    centos 关闭selinux
    前端 HTML标签属性
    前端 HTML 标签嵌套规则
    前端 HTML 标签分类
    前端 HTML body标签相关内容 常用标签 表单标签 form里面的 input标签介绍
    前端 HTML body标签相关内容 常用标签 表单标签 form 表单控件分类
    前端 HTML form表单标签 select标签 option 下拉框
    POJ 1426
  • 原文地址:https://www.cnblogs.com/dunitian/p/4869835.html
Copyright © 2011-2022 走看看