WPF中DatePiker值绑定以及精简查询

1.WPF中DatePiker值绑定
Xaml中值绑定使用Text
<DatePicker Text="{Binding strMinDate,UpdateSourceTrigger=PropertyChanged, StringFormat=yyyy-MM-dd}" HorizontalAlignment="Left" Margin="69,2,0,0" VerticalAlignment="Top" Width="137" Height="30" FontSize="14" SelectedDateFormat="Long"/>
<DatePicker Text ="{Binding strMaxDate,UpdateSourceTrigger=PropertyChanged, StringFormat=yyyy-MM-dd}" HorizontalAlignment="Left" Margin="222,2,0,0" VerticalAlignment="Top" Width="134" Height="30" FontSize="14" SelectedDateFormat="Long"/>
 
在ViewModel中使用strMinDate 转为DateTime.如下:
public string strMinDate
{
get { return this.GetProperty<string>(() => strMinDate); }
set { this.SetProperty<string>(() => strMinDate, value);
MinDateTime = Convert.ToDateTime(value);
}
} public string strMaxDate
{
get { return this.GetProperty<string>(() => strMaxDate); }
set { this.SetProperty<string>(() => strMaxDate, value);
MaxDateTime = Convert.ToDateTime(value);
}
} private DateTime? _minDateTime;
/// <summary>
/// 起始时间
/// </summary>
public DateTime? MinDateTime
{
get { return _minDateTime; }
set
{
_minDateTime = value;
this.RaisePropertyChanged(() => MinDateTime);
}
}
private DateTime? _maxDateTime;
/// <summary>
/// 结束时间
/// </summary>
public DateTime? MaxDateTime
{
get { return _maxDateTime; }
set
{
_maxDateTime = value;
this.RaisePropertyChanged(() => MaxDateTime);
}
}
 
2. Linq精简查询
 
public void Search()
{
DateTime tMin = _minDateTime == null ? DateTime.MinValue : _minDateTime.Value.Date;
DateTime tMax = _maxDateTime == null ? DateTime.MaxValue : _maxDateTime.Value.Date.AddDays(1);
IQueryable<SampleResult> IResults = _databaseContext.SampleResults.Where(x => x.Sample.ArriveDateTime < tMax && x.Sample.ArriveDateTime >= tMin && x.Sample.Barcode.Contains(Barcode)).Include(p=>p.Sample).Include(p=>p.Sample.Test).Include(p=>p.Sample.Patient);
this.Results = new ObservableCollection<SampleResult>(IResults);
}
 
3. 原代码:
Xaml:
 1 <UserControl x:Class="EUROFluoAnalyzer.Result.Views.ResultListView"
2 xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
3 xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
4 xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
5 xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
6 xmlns:dxmvvm="http://schemas.devexpress.com/winfx/2008/xaml/mvvm"
7 xmlns:ViewModels="clr-namespace:EUROFluoAnalyzer.Result.ViewModels"
8 mc:Ignorable="d"
9 DataContext="{dxmvvm:ViewModelSource Type=ViewModels:ResultListViewModel}" Height="725.373" Width="1020.746">
10 <Grid>
11 <Grid.RowDefinitions>
12 <RowDefinition Height="41"/>
13 <RowDefinition Height="45"/>
14 <RowDefinition/>
15 </Grid.RowDefinitions>
16
17 <Label Content="送检日期" HorizontalAlignment="Left" Margin="3,2,0,0" VerticalAlignment="Top" Height="22" Width="61" FontSize="14"/>
18 <DatePicker Text="{Binding strMinDate,UpdateSourceTrigger=PropertyChanged, StringFormat=yyyy-MM-dd}" HorizontalAlignment="Left" Margin="69,2,0,0" VerticalAlignment="Top" Width="137" Height="30" FontSize="14" SelectedDateFormat="Long"/>
19 <Label Content="-" HorizontalAlignment="Left" Margin="212,4,0,0" VerticalAlignment="Top" Height="22" Width="6" FontSize="14"/>
20 <DatePicker Text ="{Binding strMaxDate,UpdateSourceTrigger=PropertyChanged, StringFormat=yyyy-MM-dd}" HorizontalAlignment="Left" Margin="222,2,0,0" VerticalAlignment="Top" Width="134" Height="30" FontSize="14" SelectedDateFormat="Long"/>
21 <Label Content="样本编号" HorizontalAlignment="Left" Margin="376,4,0,0" VerticalAlignment="Top" Height="22" Width="61" FontSize="14"/>
22 <TextBox HorizontalAlignment="Left" Height="30" Margin="442,2,0,0" TextWrapping="Wrap" Text="{Binding Barcode}" VerticalAlignment="Top" Width="119" FontSize="14"/>
23 <Button Content="查询" Command="{Binding SearchCommand}" HorizontalAlignment="Left" Margin="576,2,0,0" VerticalAlignment="Top" Width="111" Height="32" FontSize="14"/>
24 <Grid Grid.Row="1">
25 <Button Content="详细" Command="{Binding DetailCommand}" HorizontalAlignment="Left" Margin="0,3,0,0" VerticalAlignment="Top" Width="111" Height="32" FontSize="14" />
26 </Grid>
27 <Grid Grid.Row="2">
28 <DataGrid ItemsSource="{Binding Results, Mode=OneWay, UpdateSourceTrigger=PropertyChanged}" Margin="0,5,0,0" IsReadOnly="True" AutoGenerateColumns="False" GridLinesVisibility="All"
29 x:Name="dataGrid"
30 SelectedItem="{Binding SelectedResult}" BorderThickness="1" HorizontalGridLinesBrush="#FFAAA5A5" VerticalGridLinesBrush="#FF9C9999" AlternatingRowBackground="#FFAEF1A7" FontSize="14">
31 <DataGrid.Columns>
32 <DataGridTemplateColumn Width="20">
33 <DataGridTemplateColumn.HeaderTemplate>
34 <DataTemplate>
35 <Grid>
36 <Border Height="18" Width="18" CornerRadius="2" Background="White" Padding="0" Margin="0" HorizontalAlignment="Center" VerticalAlignment="Center"/>
37 </Grid>
38
39 </DataTemplate>
40 </DataGridTemplateColumn.HeaderTemplate>
41 </DataGridTemplateColumn>
42 <DataGridTextColumn Header="样本编号" Width="100" Binding="{Binding Sample.Barcode}"/>
43 <DataGridTextColumn Header="样本架" Width="50" Binding="{Binding Sample.Rack}"/>
44 <DataGridTextColumn Header="管位" Width="50" Binding="{Binding Sample.Position}"/>
45 <DataGridTextColumn Header="检测项" Width="100" Binding="{Binding Sample.Test.LongName}"/>
46 <DataGridTextColumn Header="基质编号" Width="100" Binding="{Binding Order}"/>
47 <DataGridTextColumn Header="细胞核型" Width="100" Binding="{Binding CellType}"/>
48 <DataGridTextColumn Header="滴度" Width="100" Binding="{Binding Titer}"/>
49 <DataGridTextColumn Header="结果" Width="100" Binding="{Binding Result}"/>
50 <DataGridTextColumn Header="送检时间" Width="150" Binding="{Binding Sample.ArriveDateTime, StringFormat=yyyy-MM-dd HH:mm:ss}" />
51 </DataGrid.Columns>
52 </DataGrid>
53 </Grid>
54 </Grid>
55 </UserControl>
 ViewModel:

//------------------------------------------摘要------------------------------------------
// 产品名称:结果列表
// 文 件 名:ResultListViewModel
// 文件说明:
// 机器名称:EIBJDE0153
// 作  者:zhengping.pan
// 创建日期:2018-08-04 10:44:09
//---------------------------------------------------------------------------------------- using System;
using System.Linq;
using System.Data.Entity;
using DevExpress.Mvvm.DataAnnotations;
using DevExpress.Mvvm;
using System.Collections.ObjectModel;
using EUROFluoAnalyzer.Data.Table;
using EUROFluoAnalyzer.Data;
using EUROFluoAnalyzer.Result.Views; namespace EUROFluoAnalyzer.Result.ViewModels
{
[POCOViewModel]
public class ResultListViewModel : ViewModelBase
{
#region 属性
public string Barcode
{
get { return this.GetProperty<string>(() => Barcode); }
set { this.SetProperty<string>(() => Barcode, value); }
} public string strMinDate
{
get { return this.GetProperty<string>(() => strMinDate); }
set { this.SetProperty<string>(() => strMinDate, value);
MinDateTime = Convert.ToDateTime(value);
}
} public string strMaxDate
{
get { return this.GetProperty<string>(() => strMaxDate); }
set { this.SetProperty<string>(() => strMaxDate, value);
MaxDateTime = Convert.ToDateTime(value);
}
} private DateTime? _minDateTime;
/// <summary>
/// 起始时间
/// </summary>
public DateTime? MinDateTime
{
get { return _minDateTime; }
set
{
_minDateTime = value;
this.RaisePropertyChanged(() => MinDateTime);
}
}
private DateTime? _maxDateTime;
/// <summary>
/// 结束时间
/// </summary>
public DateTime? MaxDateTime
{
get { return _maxDateTime; }
set
{
_maxDateTime = value;
this.RaisePropertyChanged(() => MaxDateTime);
}
} public ObservableCollection<SampleResult> Results
{
get { return GetProperty(() => Results); }
set { SetProperty(() => Results, value); }
} public SampleResult SelectedResult
{
get { return this.GetProperty<SampleResult>(() => SelectedResult); }
set { this.SetProperty<SampleResult>(() => SelectedResult, value); }
} private EuroLabContext _databaseContext;
#endregion public ResultListViewModel()
{
Barcode = string.Empty;
strMaxDate = DateTime.Now.Date.ToString("yyyy-MM-dd");
strMinDate = new DateTime(DateTime.Now.Year,1,1).ToString("yyyy-MM-dd");
this._databaseContext = new EuroLabContext();
} public void Search()
{
DateTime tMin = _minDateTime == null ? DateTime.MinValue : _minDateTime.Value.Date;
DateTime tMax = _maxDateTime == null ? DateTime.MaxValue : _maxDateTime.Value.Date.AddDays(1);
IQueryable<SampleResult> IResults = _databaseContext.SampleResults.Where(x => x.Sample.ArriveDateTime < tMax && x.Sample.ArriveDateTime >= tMin && x.Sample.Barcode.Contains(Barcode)).Include(p=>p.Sample).Include(p=>p.Sample.Test).Include(p=>p.Sample.Patient);
this.Results = new ObservableCollection<SampleResult>(IResults);
} public void Detail()
{
if (this.SelectedResult != null)
{
IQueryable<SampleResult> IResults = _databaseContext.SampleResults.Where(x => x.Sample_ID == SelectedResult.Sample.ID && x.Sample.Protocol_ID == SelectedResult.Sample.Protocol_ID).Include(p => p.Sample).Include(p => p.Sample.Test).Include(p => p.Sample.Patient);
ResultDetailView detailWindow = new ResultDetailView();
(detailWindow.DataContext as ResultDetailViewModel).SelectedResult = this.SelectedResult;
(detailWindow.DataContext as ResultDetailViewModel).Results = new ObservableCollection<SampleResult>(IResults);
detailWindow.ShowDialog();
}
} }
}

WPF中DatePiker值绑定以及精简查询的更多相关文章

  1. WPF中,如何将绑定源设置到单件实例

    原文:WPF中,如何将绑定源设置到单件实例  WPF中,如何将绑定源设置到单件实例                                       周银辉 大概两个月前,曾有位朋友问我:如 ...

  2. 总结:WPF中模板需要绑定父级别的ViewModel该如何处理

    原文:总结:WPF中模板需要绑定父级别的ViewModel该如何处理 <ListBox ItemsSource="{Binding ClassCollection}"> ...

  3. 正确处理WPF中Slider值改变事件的方式

    最近在用WPF数据绑定重写一下播放器项目时遇到的关于Slider的问题,在窗体透明度调节和播放进度调节上用了Slider控件.调节窗体透明度我是 这么想的:将窗体的Opacity属性的值与Slider ...

  4. WPF实现多值绑定特性以及多值转换

    WPF中的实现 我们首先来看一下常规的绑定 <Window    x:Class="WpfApplicationSample.MainWindow"    xmlns=&qu ...

  5. WPF中ListBox的绑定

    WPF中列表式控件派生自ItemsControl类,继承了ItemsSource属性.ItemsSource属性可以接收一个IEnumerable接口派生类的实例作为自己的值(所有可被迭代遍历的集合都 ...

  6. wpf中的datagrid绑定操作按钮是否显示或者隐藏

    如图,需要在wpf中的datagrid的操作那列有个确认按钮,然后在某些条件下确认按钮可见,某些情况下不可见的,放在mvc里直接在cshtml页面中if..else就行了. 但是在wpf里不行..网上 ...

  7. WPF中使用ObjectDataProvider绑定方法

    ObjectDataProvider提供了绑定任意.net类型的功能,具体功能如下: 1.ObjectDataProvider提供了绑定任意CLR类型的公嫩那个. 2.它可以再XAML中利用生命史的语 ...

  8. wpf 中的DataTemplate 绑定控件

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

  9. 【WPF】WPF中的List<T>和ObservableCollection<T>

    在WPF中 控件绑定数据源时,数据源建议采用 ObservableCollection<T>集合 ObservableCollection<T> 类:表示一个动态数据集合,在添 ...

随机推荐

  1. Git仓库的提交记录乱成一团,怎么办?

    大家好,今天和大家聊聊git当中一个非常好用的功能--区间选择,它可以帮我们处理看起来非常复杂的提交记录.从而帮助我们很快找到我们需要的内容. 如果大家有参与过多人协同的项目开发,比如十几个人甚至更多 ...

  2. KepServer与S7-1200PLC之间的OPC通信配置

    对于学习上位机开发,有一种通信方式是必须要了解的,那就是OPC是OLE for Process Control的简称,然而随着技术的不断发展,人们开始对它有了新的定义,比如Open Platform ...

  3. 第二章epoll

    epoll_create:函数实现分析 /* * Open an eventpoll file descriptor. */ SYSCALL_DEFINE1(epoll_create1, int, f ...

  4. gdb调试入门(下)

    GDB调试主要包括: 1.查看运行时数据 2.程序错误 3.gdb调试逻辑错误 4.gdb调试段错误 5.core文件调试 一.查看运行时数据 1.print 查看变量值 2.ptype 变量: 查看 ...

  5. Linux_end

    1.ps 查看进程 ps 查看进程 ps aux 查看所有进程 ps -ef 查看所有进程的详细信息 2.pstree 查看进程树 3.top 查看系统的健康状况 4.netstar 显示网络统计信息 ...

  6. mybatis 多数据源动态切换

    笔者主要从事c#开发,近期因为项目需要,搭建了一套spring-cloud微服务框架,集成了eureka服务注册中心. gateway网关过滤.admin服务监控.auth授权体系验证,集成了redi ...

  7. python+selenium+chromedriver抓取shodan搜索结果

    作用:免积分抓取shodan的搜索结果,并把IP保存为txt 前提: ①shodan会员(ps:黑色星期五打折) ②安装有python27 ③谷歌浏览器(ps:版本一定要跟chromedriver匹配 ...

  8. python-基础入门-1

    Python的打印为   print,等价于c语言的printf 1 print "hello again" 就能打印出hello again,简简单单,就这么一句. 我用的vsc ...

  9. Lombok之@Builder注解

    Lombok之@Builder注解 前言 Lombok大家都知道,在使用POJO过程中,它给我们带来了很多便利,省下大量写get.set方法.构造器.equal.toString方法的时间.除此之外, ...

  10. Tarjan 算法总结

    一些概念 连通:无向图中的任意两点都可以互相到达. 强连通:有向图中的任意两点都可以互相到达. 连通分量:无向图的极大连通子图. 强连通分量:有向图的极大强连通子图. DFS 生成树:对一张图(有向无 ...