A. C#中有没有类似于SQL中的%那种通配符, 怎么在C#中实现模糊搜索(不用数据库)
1.用一个List<string> listOnit存放初始化数据,用一个List<string> listNew存放输入key之后,返回的数据。
2.用上面的listOnit初始化ComboBox数据源进行绑定。
3.在TextUpdate方法内部,添加实现方法。
首先进入方法,先清除ComboBox的内容,然后将输入的内容去listOnit初始化的数据中比对,找出对应数据,然后放入listNew存放数据,最后将listNew数据重新赋值给ComboBox。
后台代码实现:
usingSystem;
usingSystem.Collections.Generic;
usingSystem.ComponentModel;
usingSystem.Data;
usingSystem.Drawing;
usingSystem.Linq;
usingSystem.Text;
usingSystem.Windows.Forms;
namespaceTimerDemo
{
publicpartialclassForm2 : Form
{
//初始化绑定默认关键词(此数据源可以从数据库取)
List<string> listOnit = newList<string>();
//输入key之后,返回的关键词
List<string> listNew = newList<string>();
publicForm2()
{
InitializeComponent();
}
privatevoidForm2_Load(objectsender, EventArgs e)
{
//调用绑定
BindComboBox();
}
/// <summary>
/// 绑定ComboBox
/// </summary>
privatevoidBindComboBox()
{
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());
}
privatevoidcomboBox1_TextChanged(objectsender, EventArgs e)
{
/*
* 不能用TextChanged操作,当this.comboBox1.DroppedDown为True时,选择项上下键有冲突
*/
}
privatevoidcomboBox1_TextUpdate(objectsender, EventArgs e)
{
//清空combobox
this.comboBox1.Items.Clear();
//清空listNew
listNew.Clear();
//遍历全部备查数据
foreach(varitem inlistOnit)
{
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;
B. DropDownList 实现联动效果
数据库存储方式:
比如 国家地区
id name pid
1 中国 0
2 美国 0
3 北京 1
4 加州 2
5 上海 1
6 纽约 2
//pid这个就是国家地区的父ID
查询方式:
第一个list查询pid为0的数据加载到列表中,顺便把id也存一份在列表的值里。
选择事件:
第一种前台的,比如javascript或jquery:
当list的值变更时触发事件ajax-get-json,获取数据库中pid为list值为id(之前存的)的数据,javascript处理json数据加载到第二个list
第二种后台的,aspx.cs
绑定第一个list的事件并且回发,获取数据与第一种就一样了。
具体代码很简单了,在参考一下网上的例子,非常好写,祝你成功, 呵呵。