• 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。

    后台代码实现:

    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;

      

  • 相关阅读:
    心血来潮学python
    lua中的table、stack和registery
    wrapper for lua
    FT232RL变砖之后
    12.04 redmine
    Webpack 概念
    如何学习 Webpack
    React基础篇
    Intellij实用技巧
    一行代码搞定图片缩放、旋转、加水印
  • 原文地址:https://www.cnblogs.com/xilipu31/p/3993049.html
Copyright © 2020-2023  润新知