区块链技术博客
www.b2bchain.cn

日期选择器验证和AdornedElement.IsKeyboardFocused – c#程序员分享

本文介绍了日期选择器验证和AdornedElement.IsKeyboardFocused – c#程序员分享,有助于帮助完成毕业设计以及求职,是一篇很好的资料。

对技术面试,学习经验等有一些体会,在此分享。

我的表单上有一个DatePicker。当用户输入无效日期时,控件将显示红色边框。但是,我也想在错误旁边显示错误本身。

<Style TargetType="{x:Type DatePicker}">     <Setter Property="Validation.ErrorTemplate">         <Setter.Value>             <ControlTemplate>                 <StackPanel Orientation="Horizontal">                     <Border BorderThickness="1" BorderBrush="#FFdc000c" VerticalAlignment="Top">                         <Grid>                             <AdornedElementPlaceholder x:Name="adorner" Margin="-1"/>                         </Grid>                     </Border>                     <Border x:Name="errorBorder" Background="#FFdc000c" Margin="8,0,0,0"                             Opacity="0" CornerRadius="0"                             IsHitTestVisible="False"                             MinHeight="24" >                         <TextBlock Text="{Binding ElementName=adorner, Path=AdornedElement.(Validation.Errors)[0].ErrorContent}"                                    Foreground="White" Margin="8,2,8,3" TextWrapping="Wrap" VerticalAlignment="Center"/>                     </Border>                 </StackPanel>                 <ControlTemplate.Triggers>                     <DataTrigger Value="True">                         <DataTrigger.Binding>                             <Binding ElementName="adorner" Path="AdornedElement.IsKeyboardFocused" />                         </DataTrigger.Binding>                         <DataTrigger.EnterActions>                             <BeginStoryboard x:Name="fadeInStoryboard">                                 <Storyboard>                                     <DoubleAnimation Duration="00:00:00.15"                                                      Storyboard.TargetName="errorBorder"                                                      Storyboard.TargetProperty="Opacity"                                                      To="1"/>                                 </Storyboard>                             </BeginStoryboard>                         </DataTrigger.EnterActions>                         <DataTrigger.ExitActions>                             <StopStoryboard BeginStoryboardName="fadeInStoryboard"/>                             <BeginStoryboard x:Name="fadeOutStoryBoard">                                 <Storyboard>                                     <DoubleAnimation Duration="00:00:00"                                                      Storyboard.TargetName="errorBorder"                                                      Storyboard.TargetProperty="Opacity"                                                      To="0"/>                                 </Storyboard>                             </BeginStoryboard>                         </DataTrigger.ExitActions>                     </DataTrigger>                 </ControlTemplate.Triggers>             </ControlTemplate>         </Setter.Value>     </Setter>     </Style> 

我的app.xaml中包括以下内容:

<ResourceDictionary>     <ResourceDictionary.MergedDictionaries>         <ResourceDictionary Source="pack://application:,,,/<assembly>.App;component/Styles/DatePicker.xaml" />     </ResourceDictionary.MergedDictionaries> </ResourceDictionary> 

日期选择器旁边没有显示验证文本。我究竟做错了什么?

更新:
它认为这个问题与在动画中使用AdornedElement.IsKeyboardFocused有关。如果删除动画并将“不透明度”设置为1,则会显示验证,但这显然不是我要在此处实现的目标。但是,此代码可与其他控件(例如文本框,复选框)一起使用。

是否有其他替代方法可以使其正常工作?

参考方案

DatePicker是一个控件,其中IsKeyboardFocused不会填充属性(请尝试WPF检查器进行检查)。可能是因为这可能不是其典型的输入控件,并且键盘焦点可能位于日历按钮或实际文本框中。
该分辨率用于IsKeyboarFocusWithin。

<DataTrigger.Binding>   <Binding ElementName="adorner" Path="AdornedElement.(DatePicker.IsKeyboardFocusWithin)" /> </DataTrigger.Binding> 

Div单击与单选按钮相同吗? – php

有没有一种方法可以使div上的click事件与表单环境中的单选按钮相同?我只希望下面的div提交值,单选按钮很丑代码输出如下:<input id="radio-2011-06-08" value="2011-06-08" type="radio" name="radio_date&#…

故障排除“警告:session_start():无法发送会话高速缓存限制器-标头已发送” – php

我收到警告:session_start()[function.session-start]:无法发送会话缓存限制器-标头已发送(错误输出开始如果我将表单数据提交到其他文件进行处理,则可以正常工作。但是,如果我将表单数据提交到同一页面,则会出现此错误。请建议<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0…

CodeIgniter更新查询被执行两次 – php

我正在使用CodeIgniter 2.2。每次访问页面时,我都必须用+1更新数据库。代码可以工作,但是每次都会增加+2。示例:如果是total views=2,则在单击页面后total views应该是3,但是数据库中的值是4。我确定我在控制器中仅调用一次模型add_one_to_view_image。控制者 function view(){ $view_i…

jQuery Ajax文件上传在客户端浏览器上无法正常工作 – javascript

我正在尝试使用Ajax和JQuery实现个人资料图片上传功能我能够将个人资料图片成功上传到我尝试过的所有机器和移动设备上的数据库中。它适用于我在Chrome,Edge,Firefox,Safari甚至Vivaldi上使用。问题是我住在加拿大的客户无法将他们的个人资料图片上传到数据库。另外,纵向宽高比的图像倾向于向侧面旋转。我一直在要求他重​​新注册并多次提供…

将python scikit学习模型导出到pmml – python

我想将python scikit-learn模型导出到PMML。哪个python软件包最合适?我阅读了有关Augustus的内容,但是我无法使用scikit-learn模型找到任何示例。 python大神给出的解决方案 SkLearn2PMML是 JPMML-SkLearn命令行应用程序周围的薄包装。有关受支持的Scikit-Learn Estimator和…

部分转自互联网,侵权删除联系

赞(0) 打赏
部分文章转自网络,侵权联系删除b2bchain区块链学习技术社区 » 日期选择器验证和AdornedElement.IsKeyboardFocused – c#程序员分享
分享到: 更多 (0)

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

b2b链

联系我们联系我们