SilverLight 4.0 C# - 带有CheckBox列的DomainDataSource DataGrid(仅限UI - 不是数据字段),允许用户选择多个记录/行

时间:2013-01-18 01:30:54

标签: entity-framework datagrid silverlight-4.0 checkbox domaindatasource

SilverLight新手并在此处发布。请怜悯并具体说明:)

使用带有DomainDataSource和DataGrid控件的RIA服务来显示来自SQL Server查询的数据行

目标:具有复选框列(仅限UI - 不是数据字段)以允许用户选择多个记录/行

背景
1)使用RIA服务创建了新的SilverLight 4,C#解决方案

2)在ProjectName.Web

  • 创建引用SQL Server表/视图(构建解决方案)的实体框架(EF)模型。
  • 使用EF模型(构建的解决方案)创建域服务。

3)在SilverLightProjectName

  • 从“数据源”窗口中,将表拖到设计图面上以创建DomainDataSource和DataGrid(这非常适合将DataGrid绑定到数据源)

4)在MainPage.XAML中添加了复选框列

发生了什么:用户选中/选中复选框,向下滚动,向上滚动,重置所有复选框,仅检查Datagrid.SelectedItem。我已经读过这种行为是'按设计',因为分页。

<sdk:DataGrid  RowStyle="{StaticResource newDataGridStyle}"  AutoGenerateColumns="False" ItemsSource="{Binding ElementName=ddsPagerApp, Path=Data}" Name="vwPagerAppDataGrid" RowDetailsVisibilityMode="VisibleWhenSelected" MouseLeftButtonDown="vwPagerAppDataGrid_MouseLeftButtonDown" VerticalGridLinesBrush="#FFB9B9B9" FontSize="10" Grid.Row="3" SelectionChanged="vwPagerAppDataGrid_SelectionChanged" KeyDown="vwPagerAppDataGrid_KeyDown" MouseLeftButtonUp="vwPagerAppDataGrid_MouseLeftButtonUp" MouseRightButtonUp="vwPagerAppDataGrid_MouseRightButtonUp" DataContext="{Binding}" SelectionMode="Single" IsEnabled="True" IsReadOnly="False" TabIndex="2" Grid.Column="1" Margin="0,10,9,9">
        <sdk:DataGrid.Columns>                
            <sdk:DataGridTemplateColumn IsReadOnly="False">                    
                <sdk:DataGridTemplateColumn.CellEditingTemplate>
                    <DataTemplate>
                        <CheckBox  Name="ChkSelected" IsThreeState="False" IsChecked="{Binding Path=IsChecked, Mode=TwoWay}" HorizontalAlignment="Center" VerticalAlignment="Center" Unchecked="IndividualCheckBox_Unchecked" Checked="IndividualCheckBox_Checked" Width="Auto" Height="Auto" />
                    </DataTemplate>
                </sdk:DataGridTemplateColumn.CellEditingTemplate>
            </sdk:DataGridTemplateColumn>
        <sdk:DataGridTextColumn x:Name="fullNameColumn" Binding="{Binding Path=FullName}" Header="Full Name" IsReadOnly="True" />
        <sdk:DataGridTextColumn x:Name="departmentColumn" Binding="{Binding Path=department}" Header="Department" IsReadOnly="True" />
        <sdk:DataGridTextColumn x:Name="pager_number_displayColumn" Binding="{Binding Path=pager_number_display}" Header="Pager Number" IsReadOnly="True" />
        <sdk:DataGridTextColumn x:Name="PageTo" Binding="{Binding Path=PageTo}" Header="Page To" IsReadOnly="True" />
    </sdk:DataGrid.Columns>
</sdk:DataGrid>
<riaControls:DomainDataSource AutoLoad="True" d:DesignData="{d:DesignInstance my:vwPagerApp, CreateList=true}" Height="0" LoadedData="ddsPagerApp_LoadedData" Name="ddsPagerApp" QueryName="GetVwPagerAppsQuery" Width="0" Margin="10,0,25,45" Background="#FF7D0000" Foreground="#FF7D0000" Visibility="Visible">
    <riaControls:DomainDataSource.DomainContext>
        <my:NotifyDomainContext />
    </riaControls:DomainDataSource.DomainContext>
</riaControls:DomainDataSource>

尝试1:

  • 在EFModel.edmx中,添加了布尔标量属性'IsChecked'
  • 在DomainService.metadata.cs中,添加了公共bool IsChecked {get;组; }
  • MainPage.XAML中的
  • 。添加(上图)IsChecked =“{Binding Path = IsChecked,Mode = TwoWay}”

获取错误:错误11009:未映射属性''

更新:反向尝试1:

尝试2:
研究为实体定义部分类,连接到DataGrid以及使用它来跟踪CheckBox值的可能性。 有关这是否有效的建议/如何使用?

尽我所能吸收这一点。请赐教......并提前感谢您:)

1 个答案:

答案 0 :(得分:0)

这是我实施的,它工作得很漂亮。我希望将来可以帮助别人:)

1) SilverLight Project C#:使用部分类扩展实体类(在单独的文件中,但在同一名称空间内 - 编译成1个类,但保持生成的代码分开)

namespace Pager.Web
{
  public partial class pager_grp
    {
        bool _IsChecked = false;
        public bool IsChecked
        {
            get
            {return this._IsChecked;}
            set
            {this._IsChecked = !IsChecked;}
        }
    }
}

2) SilverLight项目GUI:在DataGrid中创建名为chkSelected的DataGridTemplateColumn类型的列

3) SilverLight Project XAML:使用模板并绑定到在分部类中声明的新属性

   <sdk:DataGridTemplateColumn IsReadOnly="False">                    
   <sdk:DataGridTemplateColumn.CellEditingTemplate>
        <DataTemplate>
            <CheckBox  Name="ChkSelected" IsThreeState="False" IsChecked="{Binding    Path=IsChecked, Mode=TwoWay}" HorizontalAlignment="Center" VerticalAlignment="Center" Unchecked="IndividualCheckBox_Unchecked" Checked="IndividualCheckBox_Checked" Width="Auto" Height="Auto" />
        </DataTemplate>
    </sdk:DataGridTemplateColumn.CellEditingTemplate>
</sdk:DataGridTemplateColumn>
相关问题