您好,登錄后才能下訂單哦!
本篇內容介紹了“怎么用DevExpress實現CRUD操作”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
系統背景
平臺:WPF
產品:DXGrid for WPF
本文將為大家演示如何將LinqInstantFeedbackDataSource或LinqServerModeDataSource與DXGrid一起使用,以及如何通過特殊行為在應用程序中實現CRUD操作(例如,添加、刪除、編輯)。
請注意,該測試樣本需要在您的計算機上安裝SQL Express服務。
我們為GridControl創建LINQServerModeCRUDBehavior和LINQInstantModeCRUDBehavior附加操作,例如:
<dxg:GridControl> <dxmvvm:Interaction.Behaviors> <crud:LINQServerModeCRUDBehavior ...> <crud:LINQServerModeCRUDBehavior.DataSource/> <dxsm:LinqServerModeDataSource .../> </crud:LINQServerModeCRUDBehavior.DataSource> </crud:LINQServerModeCRUDBehavior> </dxmvvm:Interaction.Behaviors> </dxg:GridControl>
LINQServerModeCRUDBehavior和LINQInstantModeCRUDBehavior類包含NewRowForm和EditRowForm屬性,以提供"Add Row" 和"Edit Row"操作。使用這些屬性,可以根據需要創建添加和編輯表單:
<DataTemplate x:Key="EditRecordTemplate"> <StackPanel Margin="8" MinWidth="200"> <Grid> <Grid.ColumnDefinitions> <ColumnDefinition/> <ColumnDefinition/> </Grid.ColumnDefinitions> <Grid.RowDefinitions> <RowDefinition/> <RowDefinition/> </Grid.RowDefinitions> <TextBlock Text="ID:" VerticalAlignment="Center" Grid.Row="0" Grid.Column="0" Margin="0,0,6,4" /> <dxe:TextEdit x:Name="txtID" Grid.Row="0" Grid.Column="1" EditValue="{Binding Path=Id, Mode=TwoWay}" Margin="0,0,0,4" /> <TextBlock Text="Name:" VerticalAlignment="Center" Grid.Row="1" Grid.Column="0" Margin="0,0,6,4" /> <dxe:TextEdit x:Name="txtCompany" Grid.Row="1" Grid.Column="1" EditValue="{Binding Path=Name, Mode=TwoWay}" Margin="0,0,0,4" /> </Grid> </StackPanel> </DataTemplate> <crud:LINQServerModeCRUDBehavior NewRowForm="{StaticResource ResourceKey=EditRecordTemplate}" EditRowForm="{StaticResource ResourceKey=EditRecordTemplate}"/>
這些操作類需要您數據模型中的以下信息:
RowType - 行的類型;
DataContext - 數據庫實體;
DataSource - LinqInstantFeedbackDataSource或LinqServerModeDataSource類型的對象。
<dxg:GridControl> <i:Interaction.Behaviors> <crud:LINQServerModeCRUDBehavior RowType="{x:Type local:Item}" DataContext="{Binding Source={StaticResource DataClassesDataContext}}"> <crud:LINQServerModeCRUDBehavior.DataSource> <dxsm:LinqServerModeDataSource KeyExpression="Id" QueryableSource="{Binding Items, Source={StaticResource DataClassesDataContext}}"/> </crud:LINQServerModeCRUDBehavior.DataSource> </crud:LINQServerModeCRUDBehavior> </i:Interaction.Behaviors> </dxg:GridControl>
請參閱 LinqServerModeDataSource和LinqInstantFeedbackDataSource類,以了解有關LinqServerModeDataSource和LinqInstantFeedbackDataSource的更多信息。
操作類的后代支持以下命令:NewRowCommand、RemoveRowCommand、EditRowCommand,您可以輕松地將交互控件與這些命令綁定在一起,例如:
<crud:LINQServerModeCRUDBehavior x:Name="helper"/> <StackPanel Grid.Row="1" Orientation="Horizontal" HorizontalAlignment="Center"> <Button Height="22" Width="60" Command="{Binding Path=NewRowCommand, ElementName=helper}">Add</Button> <Button Height="22" Width="60" Command="{Binding Path=RemoveRowCommand, ElementName=helper}" Margin="6,0,6,0">Remove</Button> <Button Height="22" Width="60" Command="{Binding Path=EditRowCommand, ElementName=helper}">Edit</Button> </StackPanel>
默認情況下,LINQServerModeCRUDBehavior和LINQInstantModeCRUDBehavior解決方案支持以下最終用戶交互功能:
最終用戶可以通過雙擊網格行或在AllowKeyDownActions屬性為True的情況下按Enter鍵來編輯選定的行值。
如果AllowKeyDownActions屬性為True,則最終用戶可以通過Delete鍵刪除選定的行。
最終用戶可以通過NewRowCommand、RemoveRowCommand和EditRowCommand命令添加、刪除和編輯新行。
“怎么用DevExpress實現CRUD操作”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。