两个ComboBox之间Item的移动

        /// <summary>
        /// 绑定权限列表的数据
        /// </summary>
        /// <param name="roleID">-1则,不获取权限列表的数据</param>
        private void DataBindCB(int roleID)
        {
            DataTable dtbPermission = PermissionDAL.GetList();
            DataTable dtbPermissionList = PermissionListDAL.GetList(roleID);
            if (dealTypeCur == DealType.Edit) permissionListOld = new List<int>();

            foreach (DataRow dr in dtbPermissionList.Rows)
            {
                if (dealTypeCur == DealType.Edit) permissionListOld.Add(Convert.ToInt32(dr["PermissionID"]));

                DataRow[] drCur = dtbPermission.Select("PermissionID=" + dr["PermissionID"].ToString());
                if (drCur.Length > 0)
                {
                    dtbPermission.Rows.Remove(drCur[0]);
                }
            }

            cbPermissionUnHas.ValueMember = "PermissionID";
            cbPermissionUnHas.DisplayMember = "Description";
            cbPermissionUnHas.DataSource = dtbPermission;

            cbPermissionHas.ValueMember = "PermissionID";
            cbPermissionHas.DisplayMember = "Description";
            cbPermissionHas.DataSource = dtbPermissionList;
        }

 

 

 

private void btnAddPermission_Click(object sender, EventArgs e)
        {
            //直接操作数据源,防止出现,设置 DataSource 属性后 无法修改项集合
            if (cbPermissionUnHas.SelectedItem == null) return;
            DataTable dtbcbPermissionHasSource = (DataTable)cbPermissionHas.DataSource;
            DataTable dtbcbPermissionUnHasSource = (DataTable)cbPermissionUnHas.DataSource;
            DataRow[] dr = dtbcbPermissionUnHasSource.Select("PermissionID=" + cbPermissionUnHas.SelectedValue.ToString());
            if (dr.Length > 0)
            {
                if (dtbcbPermissionHasSource.Rows.Count == 0)//防止因为没有数据源,而出现无法新建合适的行
                {
                    dtbcbPermissionHasSource.Columns.Add("PermissionID", typeof(int));
                    dtbcbPermissionHasSource.Columns.Add("Description", typeof(string));
                    cbPermissionHas.ValueMember = "PermissionID";//重新绑定数据,避免显示出问题
                    cbPermissionHas.DisplayMember = "Description";
                }
                DataRow drNew = dtbcbPermissionHasSource.NewRow();
                drNew["PermissionID"] = dr[0]["PermissionID"];
                drNew["Description"] = dr[0]["Description"];
                dtbcbPermissionUnHasSource.Rows.Remove(dr[0]);
                dtbcbPermissionHasSource.Rows.Add(drNew);
            }
        }

        private void btnRemovePermission_Click(object sender, EventArgs e)
        {
            if (cbPermissionHas.SelectedItem == null) return;
            DataTable dtbcbPermissionHasSource = (DataTable)cbPermissionHas.DataSource;
            DataTable dtbcbPermissionUnHasSource = (DataTable)cbPermissionUnHas.DataSource;
            DataRow[] dr = dtbcbPermissionHasSource.Select("PermissionID=" + cbPermissionHas.SelectedValue.ToString());
            if (dr.Length > 0)
            {
                if (dtbcbPermissionUnHasSource.Rows.Count == 0)
                {
                    dtbcbPermissionHasSource.Columns.Add("PermissionID", typeof(int));
                    dtbcbPermissionUnHasSource.Columns.Add("Description", typeof(string));
                    cbPermissionUnHas.ValueMember = "PermissionID";
                    cbPermissionHas.DisplayMember = "Description";
                }
                DataRow drNew = dtbcbPermissionUnHasSource.NewRow();
                drNew["PermissionID"] = dr[0]["PermissionID"];
                drNew["Description"] = dr[0]["Description"];
                dtbcbPermissionHasSource.Rows.Remove(dr[0]);
                dtbcbPermissionUnHasSource.Rows.Add(drNew);
            }
        }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值