CheckedListBox与CheckedListBox联动
包括保存和加载
//查找业务类型
DataTable dtyewu = sb.SelectSyscode(0, true);
if (dtyewu.Rows.Count > 0)
{
flagcbb = false;
clb_yewu.DataSource = dtyewu;
clb_yewu.DisplayMember = "name";
clb_yewu.ValueMember = "id";
DataRowView dr = clb_yewu.Items[0] as DataRowView;
dtyewuleixingbind(dr["id"].ToString(), true);
flagcbb = true;
}
biz = rc.Bizid.Split(';');
pit = rc.Pid.Split(';');
selectcbb();
loadbing();
private void selectcbb()
{
int m = 0;
for (int j = 0; j < clb_yewu.Items.Count; j++)
{
DataRowView dr = clb_yewu.Items[j] as DataRowView;
for (int i = 0; i < biz.Length; i++)
{
if (dr["id"].ToString() == biz[i])
{
clb_yewu.SetItemChecked(j, true);
break;
}
}
}
}
/// <summary>
/// 所有平台信息
/// </summary>
private void selectPingtai()
{
string m;
string[] pt;
DataTable dtapt = sb.SelectAllPingTai();
dtallpt.Columns.Add("id", typeof(Int32));
dtallpt.Columns.Add("cd", typeof(string));
dtallpt.Columns.Add("name", typeof(string));
for (int i = 0; i < dtapt.Rows.Count; i++)
{
m = dtapt.Rows[i][0].ToString();
pt = m.Split(';');
foreach (string ptf in pt)
{
DataRow dr = dtallpt.NewRow();
dr["id"] = dtapt.Rows[i][1].ToString();
dr["cd"] = ptf;
dr["name"] = dtapt.Rows[i][2].ToString();
dtallpt.Rows.Add(dr);
}
}
}
private void clb_yewu_SelectedIndexChanged(object sender, EventArgs e)
{
if (flagcbb)
{
string cdd = "";
int m = clb_yewu.SelectedIndex;
if (clb_yewu.CheckedItems.IndexOf(clb_yewu.Items[m]) >= 0)
dtyewuleixingbind(clb_yewu.SelectedValue.ToString(), true);
if (clb_yewu.CheckedItems.IndexOf(clb_yewu.Items[m]) <= 0)
{
dtyewuleixingbind(clb_yewu.SelectedValue.ToString(), false);
}
}
}
private void clb_SelectedIndexChanged(object sender, EventArgs e)
{
int m = ((CheckedListBox)sender).SelectedIndex;
if (((CheckedListBox)sender).CheckedItems.IndexOf(((CheckedListBox)sender).Items[m]) >= 0)
{
for (int j = 0; j < clb_yewu.Items.Count; j++)
{ DataRowView dr = clb_yewu.Items[j] as DataRowView;
if (dr["id"].ToString() == ((CheckedListBox)sender).Name)
{
clb_yewu.SetItemChecked(j, true);
break;
}
} } }
/// <summary>
/// 筛选平台
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
private DataTable selectdypt(string id)
{
DataRow[] drArr = dtallpt.Select("cd ='" + id + "'");
DataTable dtNew = dtallpt.Clone();
for (int i = 0; i < drArr.Length; i++)
{
dtNew.ImportRow(drArr[i]); }
return dtNew;
}
/// <summary>
/// 绑定平台
/// </summary>
/// <param name="id"></param>
private void dtyewuleixingbind(string id, bool select) //xu
{
//DataTable dtpingtai = sb.SelectPingtai(cdd);
DataTable dtpingtai = selectdypt(id);
bool flag = false;
foreach (Control con in panel2.Controls)
{
if (con.Name == id)
{
con.Visible = true;
flag = true;
if (!select)
{
for (int j = 0; j < ((CheckedListBox)con).Items.Count; j++)
((CheckedListBox)con).SetItemChecked(j, false);
}
}
else
{
con.Visible = false;
} }
if (!flag)
{
CheckedListBox clb_yewu = new CheckedListBox();
clb_yewu.Name = id;
clb_yewu.Visible = true;
if (dtpingtai.Rows.Count > 0)
{
clb_yewu.DataSource = dtpingtai;
clb_yewu.DisplayMember = "name";
clb_yewu.ValueMember = "id";
clb_yewu.SelectedIndexChanged += new EventHandler(clb_SelectedIndexChanged);
}
Size ss = new Size(200, 150);
clb_yewu.Size = ss;
clb_yewu.CheckOnClick = true;
panel2.Controls.Add(clb_yewu); } } #region 修改个人信息平台加载
/// <summary>
/// 平台数据加载
/// </summary>
private void loadbing()
{
if (uid > 0)
{
for (int z = 0; z < biz.Length; z++)
{
DataTable dtpingtai = selectdypt(biz[z]);
CheckedListBox clb_yewu = new CheckedListBox();
clb_yewu.Name = biz[z];
clb_yewu.Visible = true;
if (dtpingtai.Rows.Count > 0)
{
clb_yewu.DataSource = dtpingtai;
clb_yewu.DisplayMember = "name";
clb_yewu.ValueMember = "id";
} Size ss = new Size(200, 150);
clb_yewu.Size = ss;
panel2.Controls.Add(clb_yewu); }
ptbinding();
}
}
/// <summary>
/// 选中对应数据库项
/// </summary>
private void ptbinding()
{
int i = 0; foreach (Control c in panel2.Controls)
{
i = 0;
for (int j = 0; j < ((CheckedListBox)c).Items.Count; j++)
{
DataRowView dr = ((CheckedListBox)c).Items[j] as DataRowView;
if (pit != null)
foreach (string pt in pit)
{
string[] p = pt.Split('-');
if (dr["cd"].ToString() == p[0])
if (dr["id"].ToString() == p[1])
{ ((CheckedListBox)c).SetItemChecked(i, true);
break;
} }
i++; }
}
}
CheckedListBox与CheckedListBox联动的更多相关文章
- Winform开发常用控件之Checkbox和CheckedListBox
Winform的开发基本都是基于控件事件的,也就是事件驱动型的. 多选框的放置和值的获取有很多种,这里介绍几个简单常用的方法 1.直接放置Checkbox,并获取Checkbox的值 上图 做法也非常 ...
- C# CheckedListBox控件的使用方法
1. 加入项 checkedListBox1.Items.Add("蓝色"); checkedListBox1.Items.Add("红色"); checked ...
- checkedListBox的使用
. 添加项 checkedListBox1.Items.Add("蓝色"); checkedListBox1.Items.Add("红色"); checkedL ...
- CHECKEDLISTBOX用法总结
C# CHECKEDLISTBOX用法总结 一般认为:foreach (object obj in checkedListBox1.SelectedItems)即可遍历选中的值. 其实这里遍历的只 ...
- CheckedListBox与下拉框联动代码
private void yewubind(string id) { //给业务类型下拉框绑定业务类型数据 DataTable dtyewu = sb.SelectLast(id, 0); bool ...
- Winform中Checkbox与其他集合列表类型之间进行关联
本文提供了Checkbox与CheckedListBox.DataGridViewCheckBoxColumn等的联动关系 1.CheckboxAssociateFactroy.Create创建联动关 ...
- 分享两种实现Winform程序的多语言支持的解决方案
因公司业务需要,需要将原有的ERP系统加上支持繁体语言,但不能改变原有的编码方式,即:普通程序员感受不到编码有什么不同.经过我与几个同事的多番沟通,确定了以下两种方案: 方案一:在窗体基类中每次加载并 ...
- Winform中checklistbox控件的常用方法
Winform中checklistbox控件的常用方法最近用到checklistbox控件,在使用其过程中,收集了其相关的代码段1.添加项checkedListBox1.Items.Add(" ...
- C# checkboxlist的使用
最近做项目,需要用到checklistbox这一控件,由于对这一控件并不是很熟悉,导致在此浪费了一点时间. http://www.cnblogs.com/hongfei/archive/2012/12 ...
随机推荐
- Eclipse安装ADT失败解决办法
Eclipse的版本是3.5.2,配置Android的开发环境时遇到问题…… 按照Android官方文档一步步安装,到了安装Eclipse的ADT插件时,提示“requires 'org.eclips ...
- Java,javascript,html,css的关系
内容:,就是制作者放在页面想让访问者浏览的内容 . 主要由java语言提供数据检索.更新.业务处理等. 结构:使内容更加具有逻辑性和易用性,类似于1,2级标题,正文.列表等等. HTML 表现:用于修 ...
- iOS开发技巧系列---使用链式编程和Block来实现UIAlertView
UIAlertView是iOS开发过程中最常用的控件之一,是提醒用户做出选择最主要的工具.在iOS8及后来的系统中,苹果更推荐使用UIAlertController来代替UIAlertView.所以本 ...
- C# 之 Math取整
主要用到 System 命名空间下的一个数据类 Math ,调用他的方法. C#取整函数使用详解: 1.Math.Round是"就近舍入",当要舍入的是5时与"四舍五入& ...
- (inline)内联函数在IOS开发中的使用
今天在阅读YYKit源码(https://github.com/ibireme/YYKit.git)时发现在YYKitMacro.h组件中大量使用的内联函数,例如此文件中的一个函数 static in ...
- dedecms导航
{dede:global.cfg_cmsurl /} 首页链接 一级导航: {dede:channel type=“top”} [field:typelink]:导航链接 [field:typenam ...
- smarty实现缓存
首先需要在mySmarty中添加配置信息,开启缓存,设置缓存文件存放目录,设置缓存时间缓存可以实现减少访问数据库,减轻数据库压力,访问一次数据库,形成静态页面,下次直接调用这个页面,也可以用nocac ...
- mvc模式实现
listdemo.html负责显示,listModel.class.php负责从数据库存储数据和查找数据,mysql.class.php是操作数据库的类,但不直接使用,model类调用mysql,li ...
- 【转】PL/SQL编辑数据"这些查询结果不可更新,请包括ROWID或使用SELECT...FOR UPDATE获得可更新结果"处理
[转]PL/SQL编辑数据"这些查询结果不可更新,请包括ROWID或使用SELECT...FOR UPDATE获得可更新结果"处理 只要有人用了: select t.* from ...
- SQLite 入门教程(一)基本控制台(终端)命令
一.基本简介 SQLite 是一个自持的(self-contained).无服务器的.零配置的.事务型的关系型数据库引擎.因为他很小,所以也可以作为嵌入式数据库内建在你的应用程序中.SQLite 被应 ...