• C # 数据绑定(1)——将DataTabel的data添加ListView


    文/嶽永鹏

    目标界面:

    功能:通过响应UI Textbox 的值向ListView 绑定新添加的纪录。

    UI XAML 代码

     1 <Grid Margin="5">
     2             <Grid.ColumnDefinitions>
     3                 <ColumnDefinition Width="Auto"/>
     4                 <ColumnDefinition/>
     5             </Grid.ColumnDefinitions>
     6             <Grid.RowDefinitions>
     7                 <RowDefinition  Height="Auto"/>
     8                 <RowDefinition Height="Auto"/>
     9                 <RowDefinition Height="Auto"/>
    10                 <RowDefinition Height="Auto"/>
    11                 <RowDefinition Height="Auto"/>
    12                 <RowDefinition Height="Auto"/>
    13                 <RowDefinition/>
    14             </Grid.RowDefinitions>
    15             <TextBlock  Grid.Row="0" Grid.Column="0" Text="商品名称" HorizontalAlignment="Right" VerticalAlignment="Center" />
    16             <TextBox Grid.Row="0" Grid.Column="1" Margin="2" VerticalAlignment="Center" Text="{Binding Path=ComName}" Name="tbkName"/>
    17             <TextBlock  Grid.Row="1" Grid.Column="0" Text="商品进货单价" HorizontalAlignment="Right" VerticalAlignment="Center" />
    18             <TextBox Grid.Row="1" Grid.Column="1" Margin="2" VerticalAlignment="Center" Text="{Binding Path=ComInPrice}" Name="tbkInPrice"/>
    19             <TextBlock  Grid.Row="2" Grid.Column="0" Text="商品零售价格" HorizontalAlignment="Right" VerticalAlignment="Center" />
    20             <TextBox Grid.Row="2" Grid.Column="1" Margin="2" VerticalAlignment="Center" Text="{Binding Path=ComOutPrice}" Name="tbkOutPrice"/>
    21             <TextBlock  Grid.Row="3" Grid.Column="0" Text="进货数量" HorizontalAlignment="Right" VerticalAlignment="Center" />
    22             <TextBox Grid.Row="3" Grid.Column="1" Margin="2" VerticalAlignment="Center" Text="{Binding Path=ComOutPrice}" Name="tbkComCount"/>
    23             
    24             <Button Grid.Row="4" Grid.Column="1" Content="添加新纪录" Margin="2" Padding="2" Name="btnAdd" Click="btnAdd_Click" />
    25             
    26             <TextBlock Grid.Row="5" Grid.ColumnSpan="2"  HorizontalAlignment="Stretch"  VerticalAlignment="Center"  Background="Black" />
    27             
    28             <ListView Name="lstDisplay" ItemsSource="{Binding}" Grid.Row="6" Grid.ColumnSpan="2">
    29                 <ListView.View>
    30                     <GridView>
    31                         <GridView.Columns>
    32                             <GridViewColumn  Header="AutoID" DisplayMemberBinding="{Binding AutoID}"/>
    33                             <GridViewColumn Header="商品名称" DisplayMemberBinding="{Binding ComName}"/>
    34                             <GridViewColumn Header="进货价格" DisplayMemberBinding="{Binding Path=ComInPrice,StringFormat={}{0:c}}"/>
    35                             <GridViewColumn Header="零售价格" DisplayMemberBinding="{Binding Path=ComOutPrice,StringFormat={}{0:c}}"/>
    36                             <GridViewColumn Header="进货数量" DisplayMemberBinding="{Binding ComCount}"/>
    37                         </GridView.Columns>
    38                     </GridView>
    39                 </ListView.View>
    40             </ListView>
    41         </Grid>
    View Code

    c# 后台代码

     DataTable Commodity = newTable();
    
            public MainWindow()
            {
                InitializeComponent();
                //DataTable Commodity = newTable();
              
            }
    
           
    
            private void btnAdd_Click(object sender, RoutedEventArgs e)
            {
                
                addNewMember(Commodity);
                lstDisplay.DataContext = Commodity;
    
            }
    
            private void btnDelete_Click(object sender, RoutedEventArgs e)
            {
                Button b = sender as Button;
                Int32 AutoID = Convert.ToInt32(b.CommandParameter);
                delMember(Commodity, AutoID);
                lstDisplay.DataContext = Commodity;
                lstDisplay.Items.Refresh();
    
            }
    
            private DataTable delMember(DataTable Table,Int32 laction)
            {
                //Deleting  a existed row in datatable Commodity;
                DataRow delRow = Table.Rows.Find(laction);
                Table.Rows.Remove(delRow);
                return Table;
            }
    
            private  DataTable addNewMember(DataTable Table)
            {
                
    
                //inserting a new row in datatable Commodity;
    
                DataRow newRow = Table.NewRow();
                newRow["ComName"] = tbkName.Text;
                newRow["ComInPrice"] = tbkInPrice.Text;
                newRow["ComOutPrice"] = tbkOutPrice.Text;
                newRow["ComCount"] = tbkComCount.Text;
                Table.Rows.Add(newRow);
                return Table;
            }
    
    
    
            private static DataTable newTable()
            {
                //Create a new table named Commodity
                DataTable commodity = new DataTable("Commodity");
    
    
                //instert new columns
                DataColumn auto = new DataColumn("AutoID", typeof(Int32));
                //setting the column auto increment 
                auto.AutoIncrement = true;
                commodity.Columns.Add(auto);
                commodity.Columns.Add("ComName", typeof(string));
                commodity.Columns.Add("ComInPrice", typeof(double));
                commodity.Columns.Add("ComOutPrice", typeof(double));
                commodity.Columns.Add("ComCount", typeof(System.Int32));
                commodity.PrimaryKey = new DataColumn[] { commodity.Columns[0] };
                return commodity;
            }
    
           
          
    
            
    View Code
  • 相关阅读:
    js 检测浏览器
    js获取url参数
    js 使用Math函数取得数组最大最少值
    js 取一定范围内的整数
    遍历文件夹内所有文件
    'weinre' 不是内部或外部命令,也不是可运行的程序 或批处理文件。 解决方案
    解决图片缓存导致页面刷新无效果问题
    JAVA中的几种基本数据类型是什么,各自占用多少字节
    Mac终端git,svn提交代码步骤
    小程序分享链接功能
  • 原文地址:https://www.cnblogs.com/YUEYongpeng/p/3498056.html
Copyright © 2020-2023  润新知