(源码)WinForm TextBox 实现自动索引功能

简介: 有时候在项目里面需要用到类似于百度那种自动索引的功能,在WinForm里面我采用的是用一个TextBox和一个ListBox结合来实现的,大致效果如下图所示:   详细的代码如下: using System; using System.

有时候在项目里面需要用到类似于百度那种自动索引的功能,在WinForm里面我采用的是用一个TextBox和一个ListBox结合来实现的,大致效果如下图所示:

 

详细的代码如下:

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 AutoComplete
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
        DataTable dt = new DataTable();
        private void Form1_Load(object sender, EventArgs e)
        {
            BindDataList();
        }

        private void NewMethod(string CodeName)
        {
            DataTable dt_New = new DataTable();
            dt_New = dt.Clone();
            try
            {
                //克隆一张Table对其进行筛选,条件则是用户输入的字符串,模糊查询。
                DataRow[] dr = dt.Select("TCode like '%" + CodeName + "%'");
                for (int i = 0; i < dr.Length; i++)
                {
                    dt_New.ImportRow((DataRow)dr[i]);
                }
            }
            catch (Exception ex)
            {
                MessageBox.Show("Error!  " + ex.Message, "提示", MessageBoxButtons.OK, MessageBoxIcon.Error);
                return;
            }
            if (dt_New.Rows.Count > 0)
            {
                //如果数据为空则不显示ListBox
                this.lsbCode1.Visible = true;
                this.lsbCode1.Items.Clear();
                for (int i = 0; i < dt_New.Rows.Count; i++)
                {
                    //有时候字符长度不一致导致布局很难看,这里统一增加一些空格,看上去整齐一点。
                    this.lsbCode1.Items.Add(dt_New.Rows[i][0].ToString().Trim().PadRight(10) + dt_New.Rows[i][1].ToString());
                }
            }
            else
            {
                this.lsbCode1.Visible = false;
            }

        }

        /// <summary>
        /// 测试数据,实际应用中可以指定数据库里面的数据。
        /// </summary>
        void BindDataList()
        {
            dt.Columns.Add("TCode");
            dt.Columns.Add("Description");

            dt.Rows.Add("AL01", "SAP Alert Monitor SAP报警监视器");
            dt.Rows.Add("AL02", "Database alert monitor 数据库警报监测器");
            dt.Rows.Add("AL03", "Operating system alert monitor 操作系统警告监视器");
            dt.Rows.Add("AL04", "Monitor call distribution 监视呼叫分配");
            dt.Rows.Add("AL05", "Monitor current workload 监视当前的工作负荷");
            dt.Rows.Add("CO03", "显示生产订单");
            dt.Rows.Add("C005N", "Collective Release");
            dt.Rows.Add("CO11N", "Time Ticket");
            dt.Rows.Add("CO12", "Confirmation - Collective");
            dt.Rows.Add("CO13", "Confirmation - Cancel");
            dt.Rows.Add("COOIS", "Production order information system");
            dt.Rows.Add("SE01", "Transport Organizer 传送组织者");
            dt.Rows.Add("SE03", "Workbench Organizer: Tools 工作台组织器:工具");
            dt.Rows.Add("SE06", "Set Up Workbench Organizer 设置工作台组织器");
            dt.Rows.Add("SE07", "Transport System Status Display 传输系统状态显示");
            dt.Rows.Add("SE09", "Workbench Organizer 工作平台组织者");
            dt.Rows.Add("SE10", "Customizing Organizer 自定义组织者");
            dt.Rows.Add("SE11", "数据库浏览");
            dt.Rows.Add("SE16", "Data Browser: Initial Screen");
            dt.Rows.Add("SE16N", "Table Browser (the N stands for New, it replaces SE16)");
            dt.Rows.Add("SE17", "General Table Display 通用表显示");
            dt.Rows.Add("MM01", "Create Material 创建物料信息");
            dt.Rows.Add("MM02", "Modify Material 修改物料信息");
            dt.Rows.Add("MM03", "Display Material 显示物料信息");
            dt.Rows.Add("ME11", "创建采购信息记录");
            dt.Rows.Add("ME01", "维护货源清单");
            dt.Rows.Add("ME51N", "创建采购申请");
            dt.Rows.Add("ME5A", "显示采购申请清单");

        }

        private void txtCode_TextChanged(object sender, EventArgs e)
        {
            this.lsbCode1.Visible = false;
            if (txtCode.Text == "")
            {
                //如果条件为空则清空已有数据,并隐藏ListBox
                this.lsbCode1.Items.Clear();
                this.lsbCode1.Visible = false;
            }
            else
            {
                //条件不为空则执行筛选数据的函数。
                NewMethod(this.txtCode.Text.Trim());
            }
        }
    }
}

例子源码

相关文章
|
存储 机器学习/深度学习 安全
Java基础+进阶
本文适合Java入门和复习回顾。内容覆盖JDK下载和hello world、IDEA下载安装配置、类、基本数据类型、方法、修饰符、关键字、面向对象、继承、多态、接口、异常、集合、i/o流、多线程、网络编程、Lambda表达式、接口组成更新、方法引用、函数式接口、 Stream流、 反射、模块化、XML
Java基础+进阶
|
11月前
|
安全 网络安全 数据安全/隐私保护
政务内网实现https访问教程
政务内网实现HTTPS访问需经过多个步骤:了解HTTPS原理,选择并申请适合的SSL证书,配置SSL证书至服务器,设置端口映射与访问控制,测试验证HTTPS访问功能,注意证书安全性和兼容性,定期备份与恢复。这些措施确保了数据传输的安全性,提升了政务服务的效率与安全性。
|
11月前
|
弹性计算 负载均衡 监控
阿里云slb的slb-api介绍
【10月更文挑战第17天】
487 1
|
JavaScript
代码缺乏装饰?使用ts装饰器来装饰你的代码
该文章详细介绍了TypeScript中的装饰器特性,包括类装饰器、方法装饰器、属性装饰器和参数装饰器的定义与使用方法,并通过具体示例展示了装饰器在实际编码中的应用技巧。
|
12月前
|
机器学习/深度学习 自然语言处理 算法
深度学习-生成式检索-论文速读-2024-09-14(下)
深度学习-生成式检索-论文速读-2024-09-14(下)
430 0
|
SQL 物联网 Serverless
Python集成EMQX
**EMQX**是一款实现了MQTT协议的高性能消息服务器软件,支持MQTT 3.1、3.1.1及5.0等协议,并兼容HTTP、QUIC和WebSocket等多种协议,确保广泛设备接入。作为全球下载量超千万的分布式物联网MQTT服务器,EMQX能支持单集群1亿设备连接,消息分发时延低于1毫秒,适用于构建关键业务的IoT平台与应用。EMQX具备SSL/TLS加密、双向认证、基于SQL的规则引擎等功能,并采用无主分布式架构确保高可用性和水平扩展性。提供开源版与企业版自托管方案及云服务选项,满足不同需求。通过Python SDK(如Paho-MQTT)可轻松集成,实现消息的发布与订阅。
321 0
|
Linux
cmdline(二):uboot cmdline怎么传?&&cmdline kernel怎么用?
cmdline(二):uboot cmdline怎么传?&&cmdline kernel怎么用?
536 0
|
前端开发 JavaScript API
一秒钟的魔法:揭秘CSS动画的神奇效果(上)
一秒钟的魔法:揭秘CSS动画的神奇效果(上)
|
JavaScript 前端开发
37分布式电商项目 - 网站首页(广告展示)
37分布式电商项目 - 网站首页(广告展示)
77 1
|
存储 数据管理 对象存储
云存储Clouder认证:存储应用与数据管理—课时5:如何做好数据管理
云存储Clouder认证:存储应用与数据管理—课时5:如何做好数据管理