Winform如何实现ComboBox模糊查询

  最近朋友问了一个关于Winform实现ComboBox模糊查询的知识点,自己好久没有搞Winform了,就上手练了一下,废话不多说,进入正题。

前台设计:

  前台就是一个简单的Form窗体 一个ComboBox控件。

思路整理:

  1.用一个List<string> listOnit存放初始化数据,用一个List<string> listNew存放输入key之后,返回的数据。

  2.用上面的listOnit初始化ComboBox数据源进行绑定。

  3.在TextUpdate方法内部,添加实现方法。

      首先进入方法,先清除ComboBox的内容,然后将输入的内容去listOnit初始化的数据中比对,找出对应数据,然后放入listNew存放数据,最后将listNew数据重新赋值给        ComboBox。

后台代码实现:

View Code?
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;
        }
    }
}

  实现效果截图:

  从左到右模糊查询:(例如输入:张)

  可以得出正常模糊查询的结果。

  不是从左到右模糊查询呢?(例如输入:三)

  也可以查询到想要的数据,OK,完成。

  实现过程中的问题:

  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;

(0)

相关推荐

  • 加密公共类common

    common 类中的方法主要是有关MD5加密方法 和有关控件与数据库中的数据绑定的方法. 1,32位MD5加密方法 2,将sq|语句绑定到ComboBox方法 3,将sq|语句绑定ListBox控件的 ...

  • 实战|无需代码实现关键词模糊查询

    小白也能学会的关键词模糊查询功能. 一图胜千言,先来看看完成的效果图: 懂VBA的同学,可能会想到这个使用VBA中的事件完成的! 但是我们说了,今天不讲那么高深的,我们要分享是0基础也能学会的方法 具 ...

  • 【Excel】多条件查找之精确/模糊查询

    图表 各位小伙伴们,晚上好,有朋友问我,怎样多条件查询-都知道,查询函数大概有vlookup.lookup.index+match.高级点的还可以用sum.dget.sumif等众多套路实现查询的目的 ...

  • Excel最强大的符号,一个符号代替所有数据,让模糊查询变精确

    一.什么是通配符 通配符可以简单理解为能够代表excel中所有数据的符号,只要你能在excel中输入的都可以用它来表示,通配符仅仅只有两个就是问号和星号,他们都能代表任意字符,只不过代表的数量不一样 ...

  • mysql中模糊查询的四种用法:

    一.%:表示任意0个或多个字符.可匹配任意类型和长度的字符,有些情况下若是中文,请使用两个百 分号(%%)表示. *注:like '%龙%':查询出所有含有"龙"的记录 1. 所查 ...

  • VLOOKUP通配符模糊查询

    点击上方蓝字关注 Excel函数与公式 关注后发送函数名称,即可获取对应教程 个人微信号 | (ID:LiRuiExcel520) 微信服务号 | 跟李锐学Excel(ID:LiRuiExcel) 微 ...

  • 公式解释:LOOKUP反向模糊查询公式

    最近推送的五篇文章:深入理解LOOKUP:LOOKUP函数的查找原理Excel中照相机居然有如此妙用,引用照片.做仪表盘就靠它了[扩展]新手进阶必学的三个函数③:最佳劳模SUMPRODUCT函数,这篇 ...

  • 下拉式模糊查询,烧脑慎入

    利用Excel的[数据有效性]功能制作下拉菜单,应是表哥表姐耳熟能详的一个技能了. 当然,有些小伙伴可能还不会,不会的小伙伴估计是E界新人,是轻稚可爱的表弟表妹,是早晨八九点钟的太阳,是祖国--咳咳, ...

  • 通过模拟数据,使用js在前端实现模糊查询下拉框功能实例教程

    所谓模糊查询就是通过关键字在数据中匹配到包含关键字的数据,而得出的查询结果.本实例教程讲解在前端文本框输入关键字,显示匹配的数据列表功能. 首先得准备一个文本框和显示数据列表的div元素,html代码 ...

  • linqto 多个关键字模糊查询

    在Excel中,有一类函数被称为查找和引用函数,今天,小编给大家分享6个查询函数(Choose.Lookup.Hlookup.Vlookup.Match.Index)的应用技巧,可以收藏备用哦! 一. ...