C# 通过正则表达式来限制控件输入有效性

界面上允许用户输入的控件,大多是有一定限定的,比如电话号码,只允许11的数字,比如一些算法参数有取值范围限定,比如只允许[1,255]等,这种情况如果等用户输入运行后再在后台验证数据的有效性,不仅低效率而且繁琐,dev有一些控件则支持正则表达式,可以限定用户输入,这样就会很方便,这节就举例讲解两个dev常用且支持正则的控件TextEdit和GridControl。

01TextEdit

TextEdit是dev中常用的文本编辑框

<dxe:TextEdit
                            Width="150"
                            HorizontalAlignment="Left"
                            Mask="[1-9]|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5]"
                            MaskType="RegEx"
                            Text="{Binding MinGrayContrast, UpdateSourceTrigger=PropertyChanged, Mode=TwoWay}"
                            ToolTip="Value must in range [1,255]" />

这里将文本输入的有效值限定到[1,255]

02GridControl

GridControl类似于wpf默认控件库的datagrid,但是这个控件的作用强大的多,这里重点还是举例说明它正则的用法:

 <dxg:GridControl  Grid.Row="0" Grid.Column="1" MaxHeight="500" 
                    ItemsSource="{Binding PointList, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" FontSize="14" Grid.RowSpan="3"
                     HorizontalAlignment="Left"  VerticalAlignment="Top"  Margin="0" AllowLiveDataShaping="True" >
                        <dxg:GridControl.View>
                            <dxg:TableView ShowTotalSummary="True" AllowMoveColumnToDropArea="False" AllowGrouping="False" AutoExpandOnDrag="False" ShowDragDropHint="False" ShowGroupPanel="False" AllowColumnMoving="False" AllowResizing="False" RowIndicatorContentTemplate="{StaticResource rowIndicatorContentTemplate}" Header="datashow" />
                        </dxg:GridControl.View>
                        <dxg:GridColumn  Header="ID" FieldName="ID"   Width="80"/>
                        <dxg:GridColumn  Header="X(mm)" FieldName="Col"   Width="80">
                            <dxg:GridColumn.EditSettings>
                                <dxe:TextEditSettings MaskType="RegEx" Mask="[1-9]|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5]"/>
                            </dxg:GridColumn.EditSettings>
                        </dxg:GridColumn>
                        <dxg:GridColumn  Header="Y(mm)" FieldName="Row"   Width="80"/>
                        <dxg:GridColumn  Header="Z(um)" FieldName="Z"  Width="80"/>
                    </dxg:GridControl>

03效果演示

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值