Qt|QLineEdit输入限制以及给出提示并复原值

这篇具有很好参考价值的文章主要介绍了Qt|QLineEdit输入限制以及给出提示并复原值。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

参考:Qt中LineEdit编辑框限制数字输入整理
运行环境:win10,VS2022,QT6.3
2022/1/12 添加槽函数版本,要获取发送者。方便复用,可多个lineedit连同一个槽函数。
qt编辑框输入限制,C/C++/qt,qt,ui,开发语言
ui界面布局,就放了一个qlineEdit和一个button
qt编辑框输入限制,C/C++/qt,qt,ui,开发语言
undoTest.h

#pragma once

#include <QtWidgets/QMainWindow>
#include "ui_undoTest.h"

class undoTest : public QMainWindow
{
    Q_OBJECT

public:
    undoTest(QWidget *parent = Q_NULLPTR);
    
	// 设置lineedit输入范围
	void SlotLineEditLimit();
private:
    Ui::undoTestClass ui;
};

undoTest.cpp

//#pragma execution_character_set("utf-8")
#include "undoTest.h"
#include <QRegularExpression>
#include <QRegularExpressionValidator>
#include <QtCore5Compat\QRegExp>
#include <QMessageBox>
#include <QObject>
#include <QValidator>

undoTest::undoTest(QWidget *parent)
    : QMainWindow(parent)
{
    ui.setupUi(this);

    //qt5方法
    //QRegExp qregexp("[0-9\\.-]+$");
    //QValidator* validator = new QRegExpValidator(qregexp);
    //qt6方法
    QRegularExpression regExp("[0-9\\.-]+$");
    QRegularExpressionValidator* validator = new QRegularExpressionValidator(regExp, this);
    ui.lineEdit->setValidator(validator);

    connect(ui.lineEdit, &QLineEdit::editingFinished, [=](void) {
        double val = ui.lineEdit->text().toDouble();
        if (val<0||val>100)
        {
            QMessageBox box(QMessageBox::Information, QString::fromUtf8("提示"),
                QString::fromUtf8("请输入1-100范围内的数字!"), QMessageBox::Ok, this);
            box.exec();
            ui.lineEdit->setFocus();
            ui.lineEdit->setCursorPosition(ui.lineEdit->text().size());
            ui.lineEdit->selectAll();
            ui.lineEdit->undo();
        }
    });
    // or
    connect(ui.lineEdit, &QLineEdit::editingFinished, this, &undoTest::SlotLineEditLimit);

}
void undoTest::SlotLineEditLimit()
{
	QLineEdit * this_lineedit = qobject_cast<QLineEdit*>(sender());
	double val = this_lineedit->text().toDouble();
	if (val < 1 || val>100)
	{
		QMessageBox box(QMessageBox::Information, QString::fromUtf8("提示"),
			QString::fromUtf8("请输入1-100范围内的数字!"), QMessageBox::Ok, this);
		box.exec();
		this_lineedit->setFocus();
		this_lineedit->setCursorPosition(this_lineedit->text().size());
		this_lineedit->selectAll();
		this_lineedit->undo();
	}
}

main.cpp文章来源地址https://www.toymoban.com/news/detail-647374.html

#include "undoTest.h"
#include <QtWidgets/QApplication>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    undoTest w;
    w.show();
    return a.exec();
}

到了这里,关于Qt|QLineEdit输入限制以及给出提示并复原值的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Qt——QLineEdit控件常见的属性、方法和信号

    一、QLineEdit控件常见属性和方法 二、QLineEdit控件常见信号 QLineEdit:单行文本输入框控件 1. text: 描述:获取或设置文本框中的文本内容。 用法:可以使用 setText() 方法设置文本框的文本内容,或使用 text() 方法获取文本框中当前的文本。 2. placeholderText: 描述:设置一个占位

    2024年02月11日
    浏览(14)
  • Qt之输入框带自动补全提示功能

        这个功能主要是提升人机交互的体验,在输入信息时,自动读取历史信息,协助用户自动补全信息,帮助用户快速输入。 使用QComboBox代替传统文本输入框,同时将其属性改为可编辑。 可以不输入信息,下拉选择项 :代码中使用QStringList作为提示信息的输入,将其添加到

    2024年03月11日
    浏览(26)
  • QT 如何让QLineEdit的文字从最左边开始显示

    当QLineEdit的文字长度超过了控件宽度,一般而言(控件文字设为靠左对齐),用户只能看到这一长串文字的后半段部分。但是如果想让QLineEdit从最左边开始显示字符串内容呢? 举个例子,\\\"abcdefghijklmnopqrstuvwxyz0123456789\\\"这一长串字符串,在QLineEdit中显示时,可能只能看到“012

    2024年01月18日
    浏览(14)
  • 【Qt6】工具提示以及调色板设置

    工具提示即 Tool Tip,当用户把鼠标移动到某个UI对象上并悬停片刻,就会出现一个“短小精悍”的窗口,显示一些说明性文本。一般就是功能描述,让用户知道这个XX是干啥用的。 在 Qt 中使用工具提示最方便的做法是直接用 QWidget 类的成员方法:setToolTip。从 QWidget 类派生的组

    2024年02月11日
    浏览(25)
  • Qt窗体全屏与复原,子窗体全屏与复原

    QT QWidget窗体全屏时,全屏与最大化的区别时最大化有标题框全屏没有框,可以使用自带的函数: 复原时也有专门的函数: 1. 点击窗体最大化按钮实现全屏,按下ESC实现复原 如果我想在点击最大化按钮时,让窗体全屏。这个时候最好有线程的信号或者函数,通过它们来调用

    2024年02月13日
    浏览(16)
  • 运行QT的.exe程序出现缺少动态链接库以及无法定位程序输入点的两种不同情况的解决办法

    一、出现无法定位程序输入点的错误 出现这种情况是因为下面的设置造成的 因为QtCreator的环境变量在mingw环境变量的上方造成的。 具体解决办法是将上面的环境变量下移即可。 至于为什么会这样,可以自行查找啦。 二、出现缺少动态链接库dll的错误 在加入mingw-64的环境变量

    2024年02月04日
    浏览(20)
  • VS基于Qt上创建项目出现红波浪线线及项目创建不了的问题,给出个人的一个解决方法供给大家参考

    (1)我电脑上的Visual studio 2015和Qt Creator这两个软件都是安装成功可以编译运行的。 我也在Visual studio 2015平台 》 工具 -》》 更新与扩展 那里下载了Qt VS Tools,路径什么的都指定好了但是同样创建不了。 (2)过一段时间这时候我又重新把Qt VS Tools卸载重新安装, 安装好之后重

    2024年02月07日
    浏览(48)
  • vue前端el-input输入 限制输入位数以及输入规则

    前端兼容el-input输入时,仅允许输入负号、数字以及小数点,且限制整数位数以及小数位数,且不允许输入除第一个负号以外的其他符号 1、使用element-ui插件的el-input组件作为页面元素,为其绑定input事件(我这里是在表格里使用slot插入的inpu元素,所以传入参数使用scope传入)

    2024年02月09日
    浏览(17)
  • C# 限制输入为字母或数字以及长度

    日常开发过程中,验证字符的合法性一直是一个必不可少的步骤,以前都是在用户输入完再做判断,不仅麻烦在不符合标准的时候还要提示用户修改,体验很差,为什么不在输入的时候加以限制呢? 以 Winform 的 TextBox 控件为例,这里提供两种方案: 通过字符匹配 正则表达式

    2023年04月13日
    浏览(14)
  • qt学习:QT对话框+颜色+文件+字体+输入

    目录 概述 继承图 QColorDialog 颜色对话框 QFileDialog 文件对话框 保存文件对话框 QFontDialog 字体对话框 QInputDialog 输入对话框 对于对话框的功能,在GUI图形界面开发过程,使用是非常多,那么Qt也提供了丰富的对话框类 QDialog是所有对话框的基类 QWidget  QDialog QColorDialog 颜色对话框

    2024年01月21日
    浏览(27)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包