<Grid x:Name="LayoutRoot" Background="White" Height="322" Width="502">
        <sdk:DataGrid AutoGenerateColumns="False" Height="176" HorizontalAlignment="Left" Margin="60,57,0,0" Name="dg" VerticalAlignment="Top" Width="246" >
            <sdk:DataGrid.Columns>
                <sdk:DataGridTemplateColumn Width="60" >
                    <sdk:DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <StackPanel Orientation="Horizontal">
                                <CheckBox x:Name="ck" Tag="{Binding Title}" ></CheckBox>
                            </StackPanel>
                        </DataTemplate>
                    </sdk:DataGridTemplateColumn.CellTemplate>
                     </sdk:DataGridTemplateColumn>
                        <sdk:DataGridTextColumn Header="Title " Binding="{Binding Title }"></sdk:DataGridTextColumn>
                <sdk:DataGridTextColumn Header="Memo" Binding="{Binding Memo }"></sdk:DataGridTextColumn>
                <sdk:DataGridTemplateColumn Header="城市">
                    <sdk:DataGridTemplateColumn.CellTemplate>
                        <DataTemplate>
                            <ComboBox x:Name="cityData"  Loaded="City_Loaded" Tag="{Binding Kind}" SelectionChanged="cityData_SelectionChanged" />  
                        </DataTemplate>
                    </sdk:DataGridTemplateColumn.CellTemplate>
                </sdk:DataGridTemplateColumn>
            </sdk:DataGrid.Columns>
        </sdk:DataGrid>
        <Button Content="保存" Height="23" HorizontalAlignment="Left" Margin="60,11,0,0" Name="btnSave" VerticalAlignment="Top" Width="75" Click="btnSave_Click" />
        <Button Content="加载新值" Height="23" HorizontalAlignment="Left" Margin="154,11,0,0" Name="btnLoadNew" VerticalAlignment="Top" Width="75" Click="btnLoadNew_Click" />
        <Button Content="删除" Height="23" HorizontalAlignment="Left" Margin="250,11,0,0" Name="btnDel" VerticalAlignment="Top" Width="75" Click="btnDel_Click" />
        <CheckBox Content="全选" Height="16" HorizontalAlignment="Left" Margin="60,62,0,0" Name="ckAll" VerticalAlignment="Top"  Click="ckAll_Click" />
    </Grid> 
 
  public partial class BB : UserControl
    {
        List<TestItem> list = new List<TestItem>();
        public List<City> listCity = new List<City>();
        List<TestItem> lstSave = new List<TestItem>();
        public BB()
        {
            InitializeComponent();
           
          
            list.Add(new TestItem() { Title = "第一行", Memo = "Hello", Kind = "0311", Count = 100 });
            list.Add(new TestItem() { Title = "第二行", Memo = "Hello", Kind = "0311", Count = 100 });
            list.Add(new TestItem() { Title = "第三行", Memo = "Hello", Kind = "", Count = 100 });
            listCity.Add(new City() { Name = "石家庄", ValueName = "0311" });
            listCity.Add(new City() { Name = "北京", ValueName = "011" });
            dg.ItemsSource = list;
        }
        private void City_Loaded(object sender, RoutedEventArgs e)
        {
            ComboBox comboBox = sender as ComboBox;
            comboBox.ItemsSource = listCity;
            comboBox.DisplayMemberPath = "Name";
            comboBox.SelectedItem = (from model in listCity
                                     where model.ValueName == comboBox.Tag.ToString()
                                     select model).FirstOrDefault();
        }
     
        private void cityData_SelectionChanged(object sender, SelectionChangedEventArgs e)
        {
            ComboBox comboBox = sender as ComboBox;
           
        }
    
        
        private void btnLoadNew_Click(object sender, RoutedEventArgs e)
        {
            dg.ItemsSource = null;
            dg.ItemsSource = lstSave;
        }
       
        private void btnSave_Click(object sender, RoutedEventArgs e)
        {
            lstSave.Clear();
            foreach (object ovj in dg.ItemsSource)
            {
                TestItem newModel = ovj as TestItem;
                ComboBox comb = dg.Columns[3].GetCellContent(ovj).FindName("cityData") as ComboBox;
                lstSave.Add(new TestItem() { Title = "jpl", Memo = newModel.Memo, Kind = (comb.SelectedItem as City).ValueName });
                
            }
        }
      
        private void ckAll_Click(object sender, RoutedEventArgs e)
        {
            if (dg.ItemsSource != null)
            {
                if (this.ckAll.IsChecked.Value)//全选
                {
                    foreach (object ovj in dg.ItemsSource)
                    {
                        CheckBox cb1 = dg.Columns[0].GetCellContent(ovj).FindName("ck") as CheckBox; //cb为
                        cb1.IsChecked = true;
                    }
                }
                else//取消
                {
                    foreach (object obj in dg.ItemsSource)
                    {
                        CheckBox cb2 = dg.Columns[0].GetCellContent(obj).FindName("ck") as CheckBox;
                        cb2.IsChecked = false;
                    }
                }
            }
        }
        private void btnDel_Click(object sender, RoutedEventArgs e)
        {
            List<TestItem> delItem = new List<TestItem>();
            delItem.Clear();
            foreach (object ovj in dg.ItemsSource)
            {
                CheckBox cb1 = dg.Columns[0].GetCellContent(ovj).FindName("ck") as CheckBox; //cb为
                TestItem objSel = (from model in list
                                 where model.Title == cb1.Tag.ToString()
                                 select model).FirstOrDefault();
               if (cb1.IsChecked == true)
                {
                    delItem.Add(objSel);
                }
            }
            foreach (TestItem ovj in delItem)
            {
                list.Remove(ovj);
            }
            dg.ItemsSource = null;
            dg.ItemsSource = list;
        }
    }
    public class TestItem
    {
        public String Title { get; set; }
        public String Memo { get; set; }
        public String Kind { get; set; }
        public int Count { get; set; }
    }
    public class City
    {
        public string Name { get; set; }
        public string ValueName { get; set; }
    }

silverlight DataGrid 内嵌ComboBox 实现加载和保存的更多相关文章

  1. ExtJS ComboBox同时加载远程和本地数据

    ExtJS ComboBox同时加载远程和本地数据 原文:http://gblog.hbcf.net/index.php/archives/233 ComboBox比较特殊需求,将远程数据和本地数据同 ...

  2. easyui combogrid 多选加载,保存,显示代码

    1.调用代码 UTIL.SetDict($("#txt_ExcludeIndustry_"), "SECTOR_TYPE", true, true, funct ...

  3. KnockoutJS 3.X API 第七章 其他技术(1) 加载和保存JSON数据

    Knockout允许您实现复杂的客户端交互性,但几乎所有Web应用程序还需要与服务器交换数据,或至少将本地存储的数据序列化. 最方便的交换或存储数据的方式是JSON格式 - 大多数Ajax应用程序今天 ...

  4. Qt Load and Save PCL/PLY 加载和保存点云

    Qt可以跟VTK和PCL等其他库联合使用,十分强大,下面的代码展示了如何使用Qt联合PCL库来加载和保存PCL/PLY格式的点云: 通过按钮加载点云: void QMainWindow::on_pb_ ...

  5. 6.Knockout.Js(加载或保存JSON数据)

    前言 Knockout可以实现很复杂的客户端交互,但是几乎所有的web应用程序都要和服务器端交换数据(至少为了本地存储需要序列化数据),交换数据最方便的就是使用JSON格式 – 大多数的Ajax应用程 ...

  6. Knockout应用开发指南 第六章:加载或保存JSON数据

    原文:Knockout应用开发指南 第六章:加载或保存JSON数据 加载或保存JSON数据 Knockout可以实现很复杂的客户端交互,但是几乎所有的web应用程序都要和服务器端交换数据(至少为了本地 ...

  7. Tensorflow模型加载与保存、Tensorboard简单使用

    先上代码: from __future__ import absolute_import from __future__ import division from __future__ import ...

  8. TensorFlow模型加载与保存

    我们经常遇到训练时间很长,使用起来就是Weight和Bias.那么如何将训练和测试分开操作呢? TF给出了模型的加载与保存操作,看了网上都是很简单的使用了一下,这里给出一个神经网络的小程序去测试. 本 ...

  9. Knockout.Js官网学习(加载或保存JSON数据)

    前言 Knockout可以实现很复杂的客户端交互,但是几乎所有的web应用程序都要和服务器端交换数据(至少为了本地存储需要序列化数据),交换数据最方便的就是使用JSON格式 – 大多数的Ajax应用程 ...

随机推荐

  1. 改变input的value值,同时在HTML中将value进行改变

    在使用lodop进行打印的时候,需求中有这样一个功能:某个字段可以在页面的input框中进行修改. 但是在进行打印时调用的是静态的HTML代码,这就导致在页面的input框中改变字段之后,但是HTML ...

  2. 转 C++STL之string

    http://www.cnblogs.com/wangkangluo1/archive/2011/07/22/2114118.html string类的构造函数: string(const char ...

  3. 标准C程序设计七---24

    Linux应用             编程深入            语言编程 标准C程序设计七---经典C11程序设计    以下内容为阅读:    <标准C程序设计>(第7版) 作者 ...

  4. Mongodb报错:ERROR: child process failed, exited with error number 1

    Mongodb在启动时报错: 2018-10-16T11:18:54.533+0800 I CONTROL [main] Automatically disabling TLS 1.0, to for ...

  5. golang并发编程goroutine+channel(一)

    go语言的设计初衷除了在不影响程序性能的情况下减少复杂度,另一个目的是在当今互联网大量运算下,如何让程序的并发性能和代码可读性达到极致.go语言的并发关键词 "go" go dos ...

  6. sqlplus登陆scott用户,以及退出连接

    进入sqlplus界面 即登陆成功,PLsql也一样 退出连接:

  7. 74.Search in a 2D Matrix

    /* * 74.Search in a 2D Matrix * 12.5 by Mingyang * 这里面的对应挺巧的: * 这个就是将2D矩阵转化成1行数组的对应表.所以对于二分查找法的初始值为: ...

  8. [转] SQL Server中变量的声明和使用方法

    原文地址 SQL Server中变量的声明和使用方法 声明局部变量语法: DECLARE @variable_name DataType 其中 variable_name为局部变量的名称,DataTy ...

  9. 构建可读性更高的 ASP.NET Core 路由

    原文:构建可读性更高的 ASP.NET Core 路由 一.前言 不知你在平时上网时有没有注意到,绝大多数网站的 URL 地址都是小写的英文字母,而我们使用 .NET/.NET Core MVC 开发 ...

  10. centos 複製時顯示進度的指令 pv

    Pipe Viewer 的简称pv:意思是通过管道显示数据处理进度的信息.这些信息包括已经耗费的时间,完成的百分比(通过进度条显示),当前的速度,全部传输的数据,以及估计剩余的时间. yum inst ...