silverlight DataGrid 内嵌ComboBox 实现加载和保存
<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>
{
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 = "011" });
dg.ItemsSource = list;
{
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();
{
ComboBox comboBox = sender as ComboBox;
}
private void btnLoadNew_Click(object sender, RoutedEventArgs e)
{
dg.ItemsSource = null;
dg.ItemsSource = lstSave;
}
{
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 });
}
{
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为
}
}
else//取消
{
foreach (object obj in dg.ItemsSource)
{
CheckBox cb2 = dg.Columns[0].GetCellContent(obj).FindName("ck") as CheckBox;
}
}
}
{
delItem.Clear();
foreach (object ovj in dg.ItemsSource)
{
CheckBox cb1 = dg.Columns[0].GetCellContent(ovj).FindName("ck") as CheckBox; //cb为
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 = list;
}
{
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 实现加载和保存的更多相关文章
- ExtJS ComboBox同时加载远程和本地数据
ExtJS ComboBox同时加载远程和本地数据 原文:http://gblog.hbcf.net/index.php/archives/233 ComboBox比较特殊需求,将远程数据和本地数据同 ...
- easyui combogrid 多选加载,保存,显示代码
1.调用代码 UTIL.SetDict($("#txt_ExcludeIndustry_"), "SECTOR_TYPE", true, true, funct ...
- KnockoutJS 3.X API 第七章 其他技术(1) 加载和保存JSON数据
Knockout允许您实现复杂的客户端交互性,但几乎所有Web应用程序还需要与服务器交换数据,或至少将本地存储的数据序列化. 最方便的交换或存储数据的方式是JSON格式 - 大多数Ajax应用程序今天 ...
- Qt Load and Save PCL/PLY 加载和保存点云
Qt可以跟VTK和PCL等其他库联合使用,十分强大,下面的代码展示了如何使用Qt联合PCL库来加载和保存PCL/PLY格式的点云: 通过按钮加载点云: void QMainWindow::on_pb_ ...
- 6.Knockout.Js(加载或保存JSON数据)
前言 Knockout可以实现很复杂的客户端交互,但是几乎所有的web应用程序都要和服务器端交换数据(至少为了本地存储需要序列化数据),交换数据最方便的就是使用JSON格式 – 大多数的Ajax应用程 ...
- Knockout应用开发指南 第六章:加载或保存JSON数据
原文:Knockout应用开发指南 第六章:加载或保存JSON数据 加载或保存JSON数据 Knockout可以实现很复杂的客户端交互,但是几乎所有的web应用程序都要和服务器端交换数据(至少为了本地 ...
- Tensorflow模型加载与保存、Tensorboard简单使用
先上代码: from __future__ import absolute_import from __future__ import division from __future__ import ...
- TensorFlow模型加载与保存
我们经常遇到训练时间很长,使用起来就是Weight和Bias.那么如何将训练和测试分开操作呢? TF给出了模型的加载与保存操作,看了网上都是很简单的使用了一下,这里给出一个神经网络的小程序去测试. 本 ...
- Knockout.Js官网学习(加载或保存JSON数据)
前言 Knockout可以实现很复杂的客户端交互,但是几乎所有的web应用程序都要和服务器端交换数据(至少为了本地存储需要序列化数据),交换数据最方便的就是使用JSON格式 – 大多数的Ajax应用程 ...
随机推荐
- Codevs 2956 排队问题
2956 排队问题 时间限制: 1 s 空间限制: 32000 KB 题目等级 : 黄金 Gold 题目描述 Description 有N个学生去食堂,可教官规定:必须2人或3人组成一组,求有多少种不 ...
- vs2005做的留言本——天轰川下载
原文发布时间为:2008-08-01 -- 来源于本人的百度文章 [由搬家工具导入] 这个虽然单纯是个留言本,但是在功能上我都使用了尽量不重复的解决方法,所以我自认为非常适合入门级的朋友看,而且用了我 ...
- SQL 随机取出一条数据
今天遇到一需求,需要随机取出一条数据.网上找了下,sqlserver自带的有newID()这个函数,可以随机出来一个guid,用来取随机数还是蛮不错的. 直接上SQL: select top 1 *, ...
- C/C++怎样传递二维数组,转载自CSDN
用二维数组作为参数传递(用二维数组处理矩阵),但是希望接受传递二维数组参数的函数可以处理任意维度的数组(希望矩阵的行数和列数都是不固定的). [以下转帖] ---------------------- ...
- 如何使用ftrace
基本使用 1. 编译内核 ref:http://www.omappedia.org/wiki/Installing_and_Using_Ftrace========================== ...
- 隐藏video标签的下载按钮
问题: 使用video标签时,有些浏览器会显示视频的下载按钮,而这并不是我们需要的功能,必须想办法去掉. 解决方法: 使用下面的css可以达到隐藏下载按钮的效果,但是点击下载的位置,还是能出现开始下载 ...
- T1063 合并果子 codevs
http://codevs.cn/problem/1063/ 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 在一个 ...
- MySQL主从架构配置
MySQL主从架构配置有两台MySQL数据库服务器master和slave,master为主服务器,slave为从服务器,初始状态时,master和slave中的数据信息相同,当master中的数据发 ...
- 转:给 Android 开发者的 RxJava 详解
转自: http://gank.io/post/560e15be2dca930e00da1083 评注:多图解析,但是我还是未看懂. 前言 我从去年开始使用 RxJava ,到现在一年多了.今年加入 ...
- 【自用】OI计划安排表一轮
网络流√ 上下界最大流√ 线性规划转费用流√ RMQ优化建图√ 单纯形√ 字符串相关 hash√ 扩展KMP 回文自己主动机 数据结构 平衡树 启示式合并 替罪羊树 LCT 树套树 KD-Tree 二 ...