剛申請開通了博客,希望能分享自己所得,回饋博客園的各位大佬,以前從這里學了不少。
最近做一個WPF小程序,需要在DataGrid中的某列限制用戶只能輸入數字。在網上找了找,看到一些解決方法,最后是stackoverflow上的一個頁面上的方法覺得不錯,特拿來與大家分享。
方法一:從DataGridTextColumn擴展一個類:NumericTextColumn,代碼如下:
public class NumericTextColumn : DataGridTextColumn { protected override object PrepareCellForEdit(FrameworkElement editingElement, RoutedEventArgs editingEventArgs) { var edit = editingElement as TextBox; edit.PreviewTextInput += Edit_PreviewTextInput; DataObject.AddPastingHandler(edit, OnPaste); return base.PrepareCellForEdit(editingElement, editingEventArgs); } private void OnPaste(object sender, DataObjectPastingEventArgs e) { var data = e.SourceDataObject.GetData(DataFormats.Text); if (!IsDataValid(data)) e.CancelCommand(); } private void Edit_PreviewTextInput(object sender, TextCompositionEventArgs e) { e.Handled = !IsDataValid(e.Text); } bool IsDataValid(object data) { try { Convert.ToInt32(data); return true; } catch { return false; } } }
然后在XAML文件中使用它:
<DataGrid ItemsSource="{Binding SomeCollection}"> <DataGrid.Columns> <DataGridTextColumn Binding="{Binding NonNumericProperty}"/> <local:DataGridNumericColumn Binding="{Binding NumericProperty}"/> </DataGrid.Columns> </DataGrid>
方法二:使用模板
<DataGridTemplateColumn Width="100*"> <DataGridTemplateColumn.CellTemplate> <DataTemplate> <TextBlock Text="{Binding Path=NumericProperty}"/> </DataTemplate> </DataGridTemplateColumn.CellTemplate> <DataGridTemplateColumn.CellEditingTemplate> <DataTemplate> <TextBox PreviewTextInput="TextBox_PreviewTextInput" Text="{Binding Path=NumericProperty}"/> </DataTemplate> </DataGridTemplateColumn.CellEditingTemplate> </DataGridTemplateColumn>
后台代碼中加入:
private void TextBox_PreviewTextInput(object sender, TextCompositionEventArgs e) { try { Convert.ToInt32(e.Text); } catch { e.Handled = true; } }
這兩種方法都可以,方法原理也一樣,個人覺得第一種更好,可以在需要的地方方便地重用,代碼量少。
還有人說,只需要在綁定中加入字符串格式就行,例如:
<DataGridTextColumn Width="Auto" Header="Only float" Binding="{Binding Path=floatNumber, StringFormat=F5}"> </DataGridTextColumn>
試了一下,並不好使,這個方法只是綁定后按需要顯示文本的,不能限制用戶輸入。
另附微軟網站上關於數值格式字符串的定義的網址,方便以后查找: