1.用一个List<string> listOnit存放初始化数据,用一个List<string> listNew存放输入key之后,返回的数据。
2.用上面的listOnit初始化ComboBox数据源进行绑定。
3.在TextUpdate方法内部,添加实现方法。
首先进入方法,先清除ComboBox的内容,然后将输入的内容去listOnit初始化的数据中比对,找出对应数据,然后放入listNew存放数据,最后将listNew数据重新赋值给ComboBox。
后台代码实现:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
namespace TimerDemo
{
public partial class Form2 : Form
{
//初始化绑定默认关键词(此数据源可以从数据库取)
List<string> listOnit = new List<string>();
//输入key之后,返回的关键词
List<string> listNew = new List<string>();
public Form2()
{
InitializeComponent();
}
private void Form2_Load(object sender, EventArgs e)
{
//调用绑定
BindComboBox();
}
/// <summary>
/// 绑定ComboBox
/// </summary>
private void BindComboBox()
{
listOnit.Add("张三");
listOnit.Add("张思");
listOnit.Add("张五");
listOnit.Add("王五");
listOnit.Add("刘宇");
listOnit.Add("马六");
listOnit.Add("孙楠");
listOnit.Add("那英");
listOnit.Add("刘欢");
/*
* 1.注意用Item.Add(obj)或者Item.AddRange(obj)方式添加
* 2.如果用DataSource绑定,后面再进行绑定是不行的,即便是Add或者Clear也不行
*/
this.comboBox1.Items.AddRange(listOnit.ToArray());
}
private void comboBox1_TextChanged(object sender, EventArgs e)
{
/*
* 不能用TextChanged操作,当this.comboBox1.DroppedDown为True时,选择项上下键有冲突
*/
}
private void comboBox1_TextUpdate(object sender, EventArgs e)
{
//清空combobox
this.comboBox1.Items.Clear();
//清空listNew
listNew.Clear();
//遍历全部备查数据
foreach (var item in listOnit)
{
if (item.Contains(this.comboBox1.Text))
{
//符合,插入ListNew
listNew.Add(item);
}
}
//combobox添加已经查到的关键词
this.comboBox1.Items.AddRange(listNew.ToArray());
//设置光标位置,否则光标位置始终保持在第一列,造成输入关键词的倒序排列
this.comboBox1.SelectionStart = this.comboBox1.Text.Length;
//保持鼠标指针原来状态,有时候鼠标指针会被下拉框覆盖,所以要进行一次设置。
Cursor = Cursors.Default;
//自动弹出下拉框
this.comboBox1.DroppedDown = true;
}
}
}
实现效果截图:
从左到右模糊查询:(例如输入:张)
可以得出正常模糊查询的结果。
从左到右模糊查询(例如输入:三)
实现过程中的问题:
1.绑定数据一开始用的DataSource方式,但是写到下面重新给ComboBox设置数据源的时候,报错:不能为已经设置DataSource的combobox赋值。
解决方式:将赋值方式改为:Item.Add(obj)或者Item.AddRange(obj)方式
2.下拉框的内容一直在增加
解决方式:当文本框文本改变时,清空下拉框的内容,然后再添加数据。
3.输入文本改变时,没有自动弹出下拉框显示已经查询好的数据。
解决方式:设置comboBox的DroppedDown 属性为True。
4.ComboBox文本框改变事件一开始选择用的是TextChanged事件,但是当在界面用 上 下键盘选择时,出现bug,不能进行选择。
解决方式:将文本框改变事件换为TextUpdate事件,然后添加实现方法。
5.当在ComboBox输入内容时,内容文本是倒序输出的,光标位置始终在最前面。
解决方式:设置光标的显示位置,this.comboBox1.SelectionStart = this.comboBox1.Text.Length;
6.输入内容改变时,用鼠标选择下拉列表项的时候,鼠标指针消失,被下拉框覆盖掉。
解决方式:设置鼠标状态为一开始的默认状态,Cursor = Cursors.Default;
具体点啊,我不知道怎么用正则表达式啊,这个我也百度到了
追答你想要干什么,或者实现什么功能
C#中有没有类似于SQL中的%那种通配符, 怎么在C#中实现模糊搜索(不用...
1.用一个List<string> listOnit存放初始化数据,用一个List<string> listNew存放输入key之后,返回的数据。2.用上面的listOnit初始化ComboBox数据源进行绑定。3.在TextUpdate方法内部,添加实现方法。首先进入方法,先清除ComboBox的内容,然后将输入的内容去listOnit初始化的数据中比对,找出对应数据,然后...
c#有没有类似于 * 的通配符
没有,URL调用要文件名,路径信息绝对匹配才能找到,否则提示你文件不存在 url="http:\/\/www.123.com\/[通配符]001.jpg 这种写法要求在此路径下有一个文件名叫 [通配符]001.jpg 的文件存在才行
C#中 SQL语句 带参数的like 查询怎么写
SQL模糊查询,使用like比较字,加上SQL里的通配符,请参考以下:-- 1、LIKE'Mc%' 将搜索以字母 Mc 开头的所有字符串(如 McBadden)。-- 2、LIKE'%inger' 将搜索以字母 inger 结尾的所有字符串(如 Ringer、Stringer)。-- 3、LIKE'%en%' 将搜索在任何位置包含字母 en 的所有字符串...
SQL语句中含 通配符 变量 like
c#中:string sql = "select * from [table] where Col like '%" + i + "%'";vb中 sql = "select * from [table] where Col like '%" & i & "%'"
sql like语句中的%百分号
两个办法吧:第一个 在textbox.text 的语句后面加个转义的的吧 select * form tablename where fieldname like '"@ + TextBox1.Text + "'第二个办法 把SQL语句写成这样 select * form tablename where fieldname like '%" + TextBox1.Text + "%'...
T-sql中参数与like通配符的问题
keyword 这个参数哪来的。是C#的参数还是T-SQL的参数?在SQL语法里不能有T-SQL的参数。所以要把@keyword改变C#的变量。改为 string sql="select * from news where title like '%" + @keyword + "%' "其中@keyword为C#的变量
如何发送文件到网络打印机,并打印(使用C#)?
最后发现与其在C#中定义结构来对应非托管的结构,还不如直接用类来替代。所以定义了两个类 PRINTER_INFO_2以及DEVMODE(注:由于PRINTER_INFO_2中只用到了DEVMODE结构来接收打印机驱动的信息,所以只定义了这个类,对于其他类都没有做具体实现)。在PRINTER_INFO_2中,对于所有的DWORD类型数据,全部对应...
C#中怎么定义一个带括号的变量
C#中方括号是用来定义数组的表示数组的长度,而大括号是用来赋初始值的,表示这个变量的取值。1、单中括号[]①bash的内部命令, [和test是等同的。如果我们不用绝对路径指明,通常我们用的都是bash自带的命令。if\/test结构中的左中括号是调用test的命令标识,右中括号是关闭条件判断的。这个命令把它的参...
access数据库,谈谈你对该数据库的认识?(含容量、功能、规模、应用安全性...
要进行模糊查找,则必须使用通配符,ACCESS库的通配符和SQL SERVER的通配符不一样。ACCESS库的通配符为:与任何个数的字符匹配。? 与任何单个字母的字符匹配 在SQL Server中的通配符为:与任何个数的字符匹配 - 与单个字符匹配 正确写法应是:在C#里写应写成 Select * From Table Where Name Like '%...
word 中通配符 没有正则表达式中的 {0,1}功能
Word中是通配符,不是严格的正则表达式。即使是正则,不同的引擎,含义也不同。如:C#中\\d包含全角和半角数字。而在Javascript中\\d只包括半角数字。