網(wǎng)站首頁 編程語言 正文
對于瀏覽器的使用,我想大家一定不會陌生吧,輸入要搜索的內(nèi)容時,會出現(xiàn)相應(yīng)的匹配信息。
那么,今天我要講述的也是這樣一個功能。
首先看一下展示效果
輸入任意文本后,彈出具有該文本的符合項,也就是模糊查詢。
實現(xiàn)功能的核心是:QCompleter
該類可以在任何Qt小部件中提供自動完成搜索功能,例如:QLineEdit、QComboBox。當輸入指定字符后,QCompleter會根據(jù)單詞列表提供的內(nèi)容進行篩查。
在這里,我是采用QLineEdit + QCompleter組合使用的。
下面我來介紹下如何使用的吧~
1.準備基礎(chǔ)數(shù)據(jù)
想要讓QCompleter完成模糊匹配功能,前提必須要有一個可供查詢的庫文件,否則是無法搜索的。
這里就簡單插入一些字符串吧~
QStringList listData; listData << QStringLiteral("基礎(chǔ)數(shù)據(jù)1"); listData << QStringLiteral("基礎(chǔ)數(shù)據(jù)n");
2.創(chuàng)建并實例化匹配類
QCompleter *m_pCompleter = new QCompleter(listData);
設(shè)置匹配方式,在Completer中存在以下幾種匹配模式,分別列舉,如下:
模式 | 描述 |
---|---|
Qt::MatchExactly | 只匹配第一個字/詞 |
Qt::MatchFixedString | 只匹配第一個詞,并且區(qū)分大小寫 |
Qt::MatchContains | 只要字符串中包含字/詞就能匹配 |
Qt::MatchStartsWith | 與第一個字/詞進行匹配 |
Qt::MatchEndsWith | ? |
Qt::MatchCaseSensitive | 搜索區(qū)分大小寫 |
Qt::MatchRegExp | 使用正則表達式作為搜索項執(zhí)行基于字符串的匹配(Qt5.15) |
Qt::MatchRegularExpression | 使用正則表達式作為搜索項執(zhí)行基于字符串的匹配(Qt5.15) |
Qt::MatchWildcard | 使用帶有通配符的字符串作為搜索條件,執(zhí)行基于字符串的匹配 |
Qt::MatchWrap | 執(zhí)行一個環(huán)繞的搜索,這樣當搜索到達模型中的最后一項時,就會從第一個項開始,直到檢查完所有項為止 |
Qt::MatchRecursive | 搜索整個層次結(jié)構(gòu) |
在使用過程中,一般采用:Qt::MatchContains
的定義比較多。
代碼設(shè)置,如下:
m_pCompleter->setFilterMode(Qt::MatchContains);
3.控件綁定
ui.edit->setCompleter(m_pCompleter);
到此,一個簡單的模糊搜索就實現(xiàn)了,其實在使用過程中為了美觀起見,還可以對QCompleter中展示的文本進行美化~
例如:
滾動條風格
QString g_scrollVerticalWidth8Gray = "QScrollBar:vertical{ width:8px; background-color:#e9f1f7;}" "QScrollBar::handle:vertical{ width:8px; background-color:#6eade0; border-radius:4px;}" "QScrollBar::handle:vertical:hover{background-color:#2b76af;}" "QScrollBar::handle:vertical:pressed{background-color:#1e659b;}";
Completer風格
QString qsCompleterStyle = //設(shè)置:背景色、字體顏色、大小、字體風格 "QAbstractItemView{background-color:#FFFFFF;color: #FFB6C1;font-size:16px;font-family:Microsoft YaHei UI;outline:0px;}" "QAbstractItemView::item:hover{background-color:#7FFF00;color: #0000FF;}" "QAbstractItemView::item:selected{background-color:#FF8C00;color: #0000FF;}";
風格設(shè)置,如下:
m_pCompleter->popup()->setStyleSheet(qsCompleterStyle + g_scrollVerticalWidth8Gray);
單純的設(shè)置風格肯定是不行的,想要讓風格有效,必須設(shè)置:QStyledItemDelegate
QStyledItemDelegate *d = new QStyledItemDelegate; m_completerName->popup()->setItemDelegate(d);
最終展示效果,如下:
原文鏈接:https://juejin.cn/post/7155268553950625806
相關(guān)推薦
- 2022-08-19 python循環(huán)之彩色圓環(huán)實現(xiàn)示例_python
- 2022-05-17 docker停止某個容器
- 2022-03-26 C++?Primer學習記錄之變量_C 語言
- 2022-03-21 詳解C++內(nèi)存的代碼區(qū),全局區(qū),棧區(qū)和堆區(qū)_C 語言
- 2022-06-30 Python利用shutil模塊實現(xiàn)文件夾的復制刪除與裁剪_python
- 2022-06-09 Entity?Framework?Core基于數(shù)據(jù)模型創(chuàng)建數(shù)據(jù)庫_實用技巧
- 2022-08-20 Linux中sftp常用命令整理_linux shell
- 2022-08-07 QT利用QProcess獲取計算機硬件信息_C 語言
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支