zoukankan      html  css  js  c++  java
  • [转]Silverlight DatePicker 其实日期及日期格式化

    有时候会碰到一些需要设置开始日期和结束日期的需求,比如有很多商品,每件商品都有开始出售日期和结束出售日期的字段。如何使用DatePicker控件来满足这些需求呢,下文将做解答:

    1:新建SL4项目文件。新建Page页面DatePickerDemo.xaml;

    2:新建实体类Product,包含SellBegin,SellEnd 字段。代码如下:

    public class Product
    {
        public DateTime SellBegin { get; set; }
        public DateTime SellEnd { get; set; }
    }
    <navigation:Page x:Class="SLStudy.DatePickerDemo" 
               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"
               mc:Ignorable="d"
               xmlns:navigation="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Navigation"
               d:DesignWidth="640" d:DesignHeight="480"
               Title="DatePickerDemo Page" Loaded="Page_Loaded" 
               xmlns:sdk="http://schemas.microsoft.com/winfx/2006/xaml/presentation/sdk">
        <Grid x:Name="LayoutRoot">
            <sdk:DataGrid Name="dataGrid1">
            </sdk:DataGrid>
        </Grid>
    </navigation:Page>

     后台CS代码为:

    dataGrid1.ItemsSource=new List<Product>(){...};

    运行实例:结果如下:

    clip_image002

    当然如果日期格式是这样的,那用户估计会找你麻烦了。默认的日期格式应该”2010/05/05”。

    为什么前台xaml代码仅仅这样写,就可以成功的绑定数据呢?

    <sdk:DataGrid Name="dataGrid1"> </sdk:DataGrid>

    原因在于dataGrid1的AutoGenerateColumns 属性默认是true,为了实现自定义,在这里将它设置为false,并手动添加Column。代码如下:

    <sdk:DataGrid Name="dataGrid1" AutoGenerateColumns="False">
        <sdk:DataGrid.Columns>
            <sdk:DataGridTextColumn Header="起始日期" Binding="{Binding SellBegin}" />
            <sdk:DataGridTextColumn Header="结束日期" Binding="{Binding SellEnd}" />
        </sdk:DataGrid.Columns>
    </sdk:DataGrid>

    运行,结果如下:

    clip_image004

    但是编辑界面是一个文本框,用户希望的是一个日期选择框,所以需要在单元格编辑的时候,使用DataPicker。

    所以需要将<sdk:DataGridTextColumn Header="起始日期" Binding="{Binding SellBegin}" />

    修改为使用DataGridTemplateColumn ,代码如下:

    <sdk:DataGridTemplateColumn Header="起始日期">
        
        <sdk:DataGridTemplateColumn.CellTemplate>
            <DataTemplate>
                <TextBlock Text="{Binding SellBegin}" />
            </DataTemplate>
        </sdk:DataGridTemplateColumn.CellTemplate>
        
        <sdk:DataGridTemplateColumn.CellEditingTemplate>
            <DataTemplate>
                <my:DatePicker SelectedDate="{Binding SellBegin}" />
            </DataTemplate>
        </sdk:DataGridTemplateColumn.CellEditingTemplate>
        
    </sdk:DataGridTemplateColumn>

    运行效果如下:

    clip_image006

    通过运行发现,虽然选择了日期,但是起始日期的值并没有变化。为什么?

    .......

    原来虽然设置了SelectedDate的Binding,但是没有设置Binding的模式(Mode).

    于是将DataTemplete中的DatePicker修改为

    <my:DatePicker SelectedDate="{Binding SellBegin,Mode=TwoWay}" />

    Mode有三种:

    OneWay:单向绑定,数据源更改会导致控件的值变化。

    OneTime:只绑定一次。

    TwoWay:双向绑定,你变我变。

    运行后发现值变化了。

    clip_image008

    虽然值变化了,但是可以看到起始日期明显大于结束日期。

    查看DatePicker的各个属性,看到有

    DisplayDateStart 和 DisplayDateEnd 属性。

    所以我们将起始日期的DisplayDateEnd属性绑定到SellEnd 字段上。结果如下:

    <my:DatePicker SelectedDate="{Binding SellBegin,Mode=TwoWay}"

    DisplayDateEnd="{Binding SellEnd}"/>

    运行结果如下:

    image

    好了,剩下最后一步了,就是设置显示的格式了。

    第一个要明确的是,我们设置格式的对象是CellTemplete中的TextBlock对象,而不是CellEditingTemplete对象中的DatePicker对象,因为用来显示的是TextBlock对象,而编辑的是DatePicker对象。

    查看Binding 的属性,发现有StringFormat属性,代表了格式化字符串。于是修改代码为:

    <TextBlock Text="{Binding SellBegin, StringFormat=yyyy-MM-dd}" />

    运行,结果如下:

    image

    修改结束日期,最后代码如下:

    <sdk:DataGrid Name="dataGrid1" AutoGenerateColumns="False">
        <sdk:DataGrid.Columns>
            
            <sdk:DataGridTemplateColumn Header="起始日期">
                <sdk:DataGridTemplateColumn.CellTemplate>
                    <DataTemplate>
                        <TextBlock Text="{Binding SellBegin, StringFormat=yyyy-MM-dd}" />
                    </DataTemplate>
                </sdk:DataGridTemplateColumn.CellTemplate>
                <sdk:DataGridTemplateColumn.CellEditingTemplate>
                    <DataTemplate>
                        <my:DatePicker SelectedDate="{Binding SellBegin,Mode=TwoWay}"
    DisplayDateEnd="{Binding SellEnd}"/>
                    </DataTemplate>
                </sdk:DataGridTemplateColumn.CellEditingTemplate>
            </sdk:DataGridTemplateColumn>
            
            <sdk:DataGridTemplateColumn Header="结束日期">
                <sdk:DataGridTemplateColumn.CellTemplate>
                    <DataTemplate>
                        <TextBlock Text="{Binding SellEnd, StringFormat=yyyy-MM-dd}" />
                    </DataTemplate>
                </sdk:DataGridTemplateColumn.CellTemplate>
                <sdk:DataGridTemplateColumn.CellEditingTemplate>
                    <DataTemplate>
                       <my:DatePicker SelectedDate="{Binding SellEnd,Mode=TwoWay}"
    DisplayDateStart="{Binding SellBegin}"/>
                    </DataTemplate>
                </sdk:DataGridTemplateColumn.CellEditingTemplate>
            </sdk:DataGridTemplateColumn>
            
        </sdk:DataGrid.Columns>
    </sdk:DataGrid>

    运行结果如下:

    image

    本文来自LoveJenny的博客,原文地址:http://www.cnblogs.com/LoveJenny/archive/2011/06/17/2083254.html

  • 相关阅读:
    奇数
    简单的登录基于代码的
    偶数
    寻找特定的值
    'k1': 大于66的所有值, 'k2': 小于66的所有值
    差数和
    day1
    页面滑动监听
    jq的ajax初级使用
    在vue中引入swiper
  • 原文地址:https://www.cnblogs.com/wangweixznu/p/2127006.html
Copyright © 2011-2022 走看看