c#里面ComBox下拉框里面比较里面是否有这个值
//这是我写的错误的代码if(ComBox1.Items.Contains(ComBox2.Text)){ComBox1.Text=ComBox2.Text;}上面IF判...
//这是我写的错误的代码
if (ComBox1.Items.Contains(ComBox2.Text)) {
ComBox1.Text = ComBox2.Text;
}
上面IF判断里面是想判断ComBox2的文本值在ComBox1的集合里面有没有和ComBox2的文本值一样的值,假如ComBox2的文本值是“添加” 那么就判断ComBox1里面有没有“添加”这个值,如果有的话,就让ComBox1的文本值和ComBox2的相等,也就是在ComBox1的文本框里面显示“添加”。可是,我上面的代码测试了没有用。判断有问题,却不知道怎么改,求大神解答一下~~ 展开
if (ComBox1.Items.Contains(ComBox2.Text)) {
ComBox1.Text = ComBox2.Text;
}
上面IF判断里面是想判断ComBox2的文本值在ComBox1的集合里面有没有和ComBox2的文本值一样的值,假如ComBox2的文本值是“添加” 那么就判断ComBox1里面有没有“添加”这个值,如果有的话,就让ComBox1的文本值和ComBox2的相等,也就是在ComBox1的文本框里面显示“添加”。可是,我上面的代码测试了没有用。判断有问题,却不知道怎么改,求大神解答一下~~ 展开
6个回答
展开全部
你的判断没有错,是不是输入Combobox2的值有误呢?
//当你在Combobox2 输入 item 1 后点击 button1,Combobox1 的值就可以显示出来了
private void button1_Click(object sender, EventArgs e)
{
if (comboBox1.Items.Contains(comboBox2.Text))
{
comboBox1.Text = comboBox2.Text;
}
}
private void Form1_Load(object sender, EventArgs e)
{
for (int i = 0; i < 100; i++)
{
this.comboBox1.Items.Add("item " + i.ToString());
}
}
更多追问追答
追问
Combobox2.Text 没错啊,,如果是“修改”那就是修改呀。而且我这样判断的问题就是,不管Combobox2的值是什么,,哪怕是Combobox1里面有这个值,但是返回的还是没有。。。所以我就想问,该怎么判断好。
追答
你的Combobox1怎么绑定数据的呢?
你绑定数据源的时候可以循环给comboBox1.Items赋值
for (int i = 0; i < datasource.Count; i++)
{
this.comboBox1.Items.Add(datasource[i].ToString());
}
之后你就可以下面代码做判断了
if (comboBox1.Items.Contains(comboBox2.Text))
{
comboBox1.Text = comboBox2.Text;
}
展开全部
ComBox1.Items 是object类型,你去比较comBox2.Text肯定失败了。用一个list把Combox1的数据都转成String装起来,然后再进行比较
更多追问追答
追问
怎么转?求代码。。。。。。
追答
如果你的数据是 table 绑定的如下
DataRowView drv;
foreach (object obj in comboBox1.Items)
{
//绑定 table 用 DataRowView,如果是直接添加的 obj.toString()
drv = obj as DataRowView;
if (drv != null)
{
drv.Row["字段"].ToString();
}
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你试试返回你需要搜索的文本在ComBox1里的索引号,判断索引号是否存在.
用try{} catch{} 试试
用try{} catch{} 试试
更多追问追答
追问
cmbButtonImg.Items.IndexOf(“文本”) 这样么? 这样判断就一直是 -1 也就是空的。
追答
所以叫你用try{} catch{}语句呀
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
private void button1_Click(object sender, EventArgs e)
{
if (comboBox1.Items.Contains(comboBox2.Text))
{
comboBox1.Text = comboBox2.Text;
}
}
我测试过了!没有问题,我估计你的comboBox2.Text没有选中值,comboBox2.Text取的是当前combobox框里的文本,你必须选中才行,如果要直接比对,那你就要循环了,循环combobox2里的item的text,代码如下:
for (int i = 0; i < comboBox2.Items.Count; i++)
{
string value = comboBox2.Items[i].ToString();
if (comboBox1.Items.Contains(value))
{
comboBox1.Text = value;
comboBox2.Text = value;
break;
}
}
{
if (comboBox1.Items.Contains(comboBox2.Text))
{
comboBox1.Text = comboBox2.Text;
}
}
我测试过了!没有问题,我估计你的comboBox2.Text没有选中值,comboBox2.Text取的是当前combobox框里的文本,你必须选中才行,如果要直接比对,那你就要循环了,循环combobox2里的item的text,代码如下:
for (int i = 0; i < comboBox2.Items.Count; i++)
{
string value = comboBox2.Items[i].ToString();
if (comboBox1.Items.Contains(value))
{
comboBox1.Text = value;
comboBox2.Text = value;
break;
}
}
追问
不是这样,,我换一种简单的说法吧。。就是用指定的文本,去查找控件哪一项的文本与之相同,就返回哪一项的索引号,没找到任何匹配项就返回-1。就是用ComBox2的文本找ComBox1的那一项文本和它相同。 这样的判断应该怎么写呢~~我给你加分哦~大神。
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
int n=-1;
for(int i=0;i<this.ComBox1.Items.Count;i++)
{
if(this.ComBox1.items[i].ToString().Trim()==This.ComBox2.Text.Trim())
{
n= i;
break;
}
}
this.ComBox1.SelectedIndex =n;
这样就是你想要的效果;符合要求的返回索引,否则返回-1;
for(int i=0;i<this.ComBox1.Items.Count;i++)
{
if(this.ComBox1.items[i].ToString().Trim()==This.ComBox2.Text.Trim())
{
n= i;
break;
}
}
this.ComBox1.SelectedIndex =n;
这样就是你想要的效果;符合要求的返回索引,否则返回-1;
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询