zoukankan      html  css  js  c++  java
  • Windows Phone开发(14):数据模板 转:http://blog.csdn.net/tcjiaan/article/details/7350849

    数据模板,如果你仅仅听到这个名词,你一定很迷惑,什么来的?用来干什么的?不急,亲,今天,我们一起来探索一下吧。
    用白话文说,数据模板就是用来规范数据的显示方式的,关于模板,估计各位不陌生的,大家应该玩过PPT吧,都做过演示文稿吧,对啊,PPT里面有很多模板的,明白了吧?不明白?那你一定填过表吧,如果报考什么考试的,你肯定会被要求填一些什么报名表之类的,或者说,找过工用吗?是啊,做简历也有简历模板。模板的用法就像做填空题,有了部分规范的内容,然后你按照这个规范,在特定的位置填上恰当的内容,你总不能说把你的姓名填到“性别”那里去吧,这就不符合规范了。
    好了,废话讲了不少,下面进入正题,你想想,哪些控件最有可能用到数据模板?哈,其实很多,只要是ContentControl的子类基本上都可以,如Button等,当然,这些控件一般没那必要,按钮嘛,多数情况下显示一些文本提示用户用来干什么的就可以了,顶多你放个图标在按钮上,估计也很少人把一段视频放在按钮上吧,呵呵,其实,在WP里面,这是可以的,但没有必要。
    对的,一般列表形式的控件就最有可能使用到数据模板了,比如ListBox控件,如果你的列表控件只是让用户看信息的,而不需要额外操作,你完全可以考虑使用ListBox的“老爸”——ItemsControl。

    好,下面我们用一个例子看看在不自定义数据模板的情况下,ItemsControl的列表项是如何显示的。
    首先,当然是新建一个项目了,不用我介绍,相信各位都会。
    你完全可以这样,把页面内的Grid根容器都删除,直接扔一个ItemsControl上面,就像这样。

    1. <phone:PhoneApplicationPage   
    2.     x:Class="DataTemplateSample.pageA"  
    3.     xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"  
    4.     xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"  
    5.     xmlns:phone="clr-namespace:Microsoft.Phone.Controls;assembly=Microsoft.Phone"  
    6.     xmlns:shell="clr-namespace:Microsoft.Phone.Shell;assembly=Microsoft.Phone"  
    7.     xmlns:d="http://schemas.microsoft.com/expression/blend/2008"  
    8.     xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"  
    9.     FontFamily="{StaticResource PhoneFontFamilyNormal}"  
    10.     .......  
    11.     >  
    12.   
    13.     <ItemsControl x:Name="myItemControl"/>  
    14.   
    15. </phone:PhoneApplicationPage>  


    然后,切换到代码页,把myItemControl的数据源设置为一个字符串数组。

    1. public pageA()  
    2. {  
    3.     InitializeComponent();  
    4.   
    5.     this.myItemControl.ItemsSource = new string[] {  
    6.                 "玉米炒蛋",  
    7.                 "烧鸭饭",  
    8.                 "青瓜炒肉",  
    9.                 "水煮豆腐",  
    10.                 "糯米鸡"  
    11.     };  
    12. }  


    好的,不要流口水啊,现在,你可以运行你的超级项目了。
    你应该发现了,列表的每一项都是以文本的方式显示,其实,它内部默认就是一个TextBlock,就是用来显示文本的。
    那么,如果我设置的数据源不是字符会怎么样呢?
    好现在看第二个例子。
    先做好布局,和刚才的例子一样。

    1. <phone:PhoneApplicationPage   
    2.     x:Class="DataTemplateSample.pageB"  
    3.     xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"  
    4.     xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"  
    5.     xmlns:phone="clr-namespace:Microsoft.Phone.Controls;assembly=Microsoft.Phone"  
    6.     xmlns:shell="clr-namespace:Microsoft.Phone.Shell;assembly=Microsoft.Phone"  
    7.     xmlns:d="http://schemas.microsoft.com/expression/blend/2008"  
    8.     xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"  
    9.      .......  
    10.     >  
    11.   
    12.     <ItemsControl Name="myItemsControl" FontSize="52"/>  
    13.   
    14. </phone:PhoneApplicationPage>  


    接着我们定义一个商品类,包含三个属性:商品名称,单价,条码。
    并把ItemsControl的数据源设置为商品类的集合。

    1. public partial class pageB : PhoneApplicationPage  
    2. {  
    3.     public pageB()  
    4.     {  
    5.         InitializeComponent();  
    6.   
    7.         System.Collections.ObjectModel.ObservableCollection<Goods> goodsList = new System.Collections.ObjectModel.ObservableCollection<Goods>  
    8.         {  
    9.             new Goods{GoodsName="纸飞机",Price=0.02f,BarCode ="21001475"},  
    10.             new Goods{GoodsName="鸡蛋",Price=0.6f,BarCode="21002345"},  
    11.             new Goods{GoodsName="干面包",Price=2.5f,BarCode="21003087"},  
    12.             new Goods{GoodsName="地沟油",Price=33.4f,BarCode="21002020"},  
    13.             new Goods{GoodsName="茅台啤酒",Price=108f,BarCode="21009331"}  
    14.         };  
    15.         this.myItemsControl.ItemsSource = goodsList;  
    16.     }  
    17. }  
    18.   
    19. public class Goods  
    20. {  
    21.     /// <summary>  
    22.     /// 商品价格  
    23.     /// </summary>  
    24.     public string GoodsName { getset; }  
    25.   
    26.     /// <summary>  
    27.     /// 商品单价  
    28.     /// </summary>  
    29.     public float Price { getset; }  
    30.   
    31.     /// <summary>  
    32.     /// 商品条形码  
    33.     /// </summary>  
    34.     public string BarCode { getset; }  
    35. }  


     

    运行一下,啊,你会大吃一惊,怎么显示这内容?
    (图1)

    前文说了,数据模板默认是TextBlock控件,只能显示文本,那么,当它遇到非文本数据时,就会尝试调用数据源中类型的ToString方法,所以刚才的示例才会显示出类名,这是从Object类继承过来的ToString方法,现在我们把Goods类改一下,重写它的ToString方法,看看结果是啥。

    1. public override string ToString()  
    2. {  
    3.     return this.GoodsName;  
    4. }  


     

    这时候你再运行一下,看到商品名称了吧?

    然而,你会发现,好像还没有满足我们的需求,我们希望每一项中同时显示商品名,单价,条码值,那怎么办呢?是的,这时候,就真的要自定义数据模板了。

    把上面的XAML改一下。

    1. <ItemsControl Name="myItemsControl" FontSize="52">  
    2.     <ItemsControl.ItemTemplate>  
    3.         <DataTemplate>  
    4.             <Grid Margin="0,0,0,27">  
    5.                 <Grid.ColumnDefinitions>  
    6.                     <ColumnDefinition Width="auto"/>  
    7.                     <ColumnDefinition Width="*"/>  
    8.                 </Grid.ColumnDefinitions>  
    9.                 <Grid.RowDefinitions>  
    10.                     <RowDefinition Height="auto"/>  
    11.                     <RowDefinition Height="auto"/>  
    12.                     <RowDefinition Height="auto"/>  
    13.                 </Grid.RowDefinitions>  
    14.                 <TextBlock Grid.Column="0" Grid.Row="0" Text="商品:"/>  
    15.                 <TextBlock Grid.Column="1" Grid.Row="0" Text="{Binding GoodsName}"/>  
    16.                 <TextBlock Grid.Column="0" Grid.Row="1" Text="单价:"/>  
    17.                 <TextBlock Grid.Column="1" Grid.Row="1" Text="{Binding Price}"/>  
    18.                 <TextBlock Grid.Column="0" Grid.Row="2" Text="条码:"/>  
    19.                 <TextBlock Grid.Column="1" Grid.Row="2" Text="{Binding BarCode}"/>  
    20.             </Grid>  
    21.         </DataTemplate>  
    22.     </ItemsControl.ItemTemplate>  
    23. </ItemsControl>  


    好了,现在就基本达到我们的要求了。
    (图2)

  • 相关阅读:
    快学Scala 第6章 对象
    Ch05 类
    Ch04 映射和元组
    Ch03 数组相关操作
    Ch02 控制结构和函数
    Ch01 基础
    28.创建对象两种方式、对象的方法、属性、获取属性值的两种方法、属性名含特殊符号时获取属性值的方法、添加属性及值的方法、删除属性的方法、使用方式、遍历对象属性for(var prop in obj)
    27.函数循环扩展作业、非常重要涉及编程思想(一天看一遍) 编程思想其实就是算法,、感悟、演算
    26 .闭包 、函数表达式在for中无法接受实时改变的变量、 在for里要将函数表达式封装成闭包才能接受实时变化的参数,并要将函数表达式return出去
    25.函数例题-预解析 作用域 、函数变量优先级、全局变量污染(直接在全局声明 、 函数里的变量没声明)但是函数里的变量没声明造成的全局变量污染有个前提,函数要被调用)
  • 原文地址:https://www.cnblogs.com/songtzu/p/2607158.html
Copyright © 2011-2022 走看看