GridView gv = new GridView();
DataTable dt = fieldManageBLL.GetFieldManage(moduleName);
for(int i=0;i<dt.Rows.Count;i++)
{
if(i==0)
{
GridViewColumn gvc=new GridViewColumn();
CheckBox cb = new CheckBox();
cb.Checked += new RoutedEventHandler(new SupplierPayBill().cb_Checked);
cb.Content = new TextBlock().Text = "全选";
_gvc.Header = cb;
_gvc.Width = 100;
_gvc.CellTemplate = (DataTemplate)resources["TheCheckBox"];
gv.Columns.Add(_gvc);
continue;
}
gvc.DisplayMemberBinding = new Binding(dt.Rows[i]["FieldManage_Field"].ToString());
}
return gv;
//其中:dt.Rows[i]["FieldManage_Field"].ToString();分别对应以下DataTemplate中的x:Key的值。
//至于DisplayMemberBinding我才接触几天,目前的理解是只显示数据而没有其它效果;而CellTemplate则可以在显示的数据上加上控件的效果,,比如CheckBox、Hyperlink等
//XAML代码:
<Window.Resources>
<!-- 复选框 -->
<DataTemplate x:Key="TheCheckBox">
<TextBlock VerticalAlignment="Center">
<CheckBox Name="ckb_SelectAll" Click="ckb_SelectAll_Click" Margin="6 0 0 0">
<!--<TextBlock Foreground="White">全选</TextBlock>-->
</CheckBox>
</TextBlock>
</DataTemplate>
<!-- 序号 -->
<DataTemplate x:Key="TheIndex">
<TextBlock Width="100" Text="{Binding Path=TheIndex}" Style="{StaticResource NormalTextBlockStyle}" TextAlignment="Center"></TextBlock>
</DataTemplate>
<!--单据号-->
<DataTemplate x:Key="StoBill_No">
<TextBlock Width="150" Text="{Binding Path=StoBill_No}" Tag="{Binding Path=StoBill_ID}" Style="{StaticResource NormalTextBlockStyle}" TextAlignment="Right" Padding="0,0,20,0"></TextBlock>
</DataTemplate>
<!--单据类型-->
<DataTemplate x:Key="StoBillsType_Name">
<TextBlock Width="100" Text="{Binding Path=StoBillsType_Name }" Style="{StaticResource NormalTextBlockStyle}" TextAlignment="Center"></TextBlock>
</DataTemplate>
<!--时间-->
<DataTemplate x:Key="StoBill_OperationDate">
<TextBlock Width="150" Text="{Binding Path=StoBill_OperationDate,StringFormat=‘{}{0:yyyy-MM-dd HH:mm}‘}" Style="{StaticResource NormalTextBlockStyle}" TextAlignment="Left"></TextBlock>
</DataTemplate>
<!--应付-->
<DataTemplate x:Key="StoBill_NotPaid">
<TextBlock Width="100" Text="{Binding Path=StoBill_NotPaid,StringFormat=‘N‘}" Style="{StaticResource NormalTextBlockStyle}" TextAlignment="Right" Padding="0,0,20,0"></TextBlock>
</DataTemplate>
<!--单据明细-->
<DataTemplate x:Key="DanjuDetail">
<TextBlock TextAlignment="Center" Width="100" >