当前位置: 首页 > news >正文

支付招聘网站套餐费用怎么做帐wordpress preg_replace 关键词 alt

支付招聘网站套餐费用怎么做帐,wordpress preg_replace 关键词 alt,株洲seo,wordpress 主题栏目修改Qt输入数据验证的方法 一、Qt输入数据验证二、Qt输入数据验证的方法1、数字输入验证2、字符串输入验证QValidator 验证器使用正则表达式自定义验证逻辑信号与槽机制 三、验证反馈四、总结五、实战1、效果查看2、源码分享 一、Qt输入数据验证 在Qt中,输入数据验证可…

Qt输入数据验证的方法

  • 一、Qt输入数据验证
  • 二、Qt输入数据验证的方法
    • 1、数字输入验证
    • 2、字符串输入验证
      • QValidator 验证器
      • 使用正则表达式
      • 自定义验证逻辑
      • 信号与槽机制
  • 三、验证反馈
  • 四、总结
  • 五、实战
    • 1、效果查看
    • 2、源码分享

一、Qt输入数据验证

  • 在Qt中,输入数据验证可以通过多种方式实现,主要涉及QValidator类、正则表达式、信号与槽机制以及自定义验证逻辑。以下是几种常见的验证方法。
  • 在软件开发中,用户输入数据的验证是一项至关重要的任务。不正确的输入可能导致程序崩溃、数据损坏或安全漏洞。Qt提供了一系列强大的工具来帮助开发者有效地验证和过滤用户输入。

二、Qt输入数据验证的方法

1、数字输入验证

对于数字输入,Qt提供了专门的控件来简化验证过程:
QSpinBox 和 QDoubleSpinBox

// 创建一个整数输入框,范围0-100
QSpinBox *spinBox = new QSpinBox(this);
spinBox->setRange(0, 100);
spinBox->setSingleStep(1);
spinBox->setValue(50);// 创建一个浮点数输入框,范围0.0-1.0
QDoubleSpinBox *doubleSpinBox = new QDoubleSpinBox(this);
doubleSpinBox->setRange(0.0, 1.0);
doubleSpinBox->setSingleStep(0.1);
doubleSpinBox->setValue(0.5);

日期和时间输入

// 日期输入
QDateEdit *dateEdit = new QDateEdit(QDate::currentDate(), this);
dateEdit->setDisplayFormat("yyyy-MM-dd");
dateEdit->setCalendarPopup(true);// 时间输入
QTimeEdit *timeEdit = new QTimeEdit(QTime::currentTime(), this);
timeEdit->setDisplayFormat("hh:mm:ss");

2、字符串输入验证

对于字符串输入,Qt提供了验证器(Validator)和输入掩码(Input Mask)两种主要方式。

QValidator 验证器

Qt提供了QValidator类及其子类(如QIntValidator、QDoubleValidator、QRegularExpressionValidator )来验证输入内容。这些验证器可以直接应用于QLineEdit等输入控件。

// 整数验证器
QLineEdit *intEdit = new QLineEdit(this);
QIntValidator *intValidator = new QIntValidator(0, 100, this);
intEdit->setValidator(intValidator);// 浮点数验证器
QLineEdit *doubleEdit = new QLineEdit(this);
QDoubleValidator *doubleValidator = new QDoubleValidator(0.0, 1.0, 2, this);
doubleValidator->setNotation(QDoubleValidator::StandardNotation);
doubleEdit->setValidator(doubleValidator);// 正则表达式验证器 - 验证电子邮件格式
QLineEdit *emailEdit = new QLineEdit(this);
QRegularExpressionValidator *emailValidator = new QRegularExpressionValidator(QRegularExpression("\\b[A-Z0-9._%+-]+@[A-Z0-9.-]+\\.[A-Z]{2,}\\b", QRegularExpression::CaseInsensitiveOption), this);
emailEdit->setValidator(emailValidator);

使用正则表达式

QRegularExpressionValidator 允许通过正则表达式进行更灵活的验证。例如,验证电子邮件格式:

QLineEdit *emailEdit = new QLineEdit();
QRegExp rx("[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,4}");
QRegularExpressionValidator *validator = new QRegularExpressionValidator (rx, emailEdit);
emailEdit->setValidator(validator);

正则表达式[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,4}匹配常见的电子邮件格式。

自定义验证逻辑

对于复杂验证需求,可以继承QValidator并重写validate方法。例如,验证密码强度:

class PasswordValidator : public QValidator {
public:State validate(QString &input, int &pos) const override {if (input.length() < 8) {return Intermediate;}if (!input.contains(QRegExp("[A-Z]")) || !input.contains(QRegExp("[0-9]"))) {return Intermediate;}return Acceptable;}
};QLineEdit *passwordEdit = new QLineEdit();
passwordEdit->setValidator(new PasswordValidator());

此验证器要求密码长度至少为8个字符,且包含至少一个大写字母和一个数字。

信号与槽机制

通过连接输入控件的信号(如textChanged)到自定义槽函数,可以实现实时验证。例如:

QLineEdit *userEdit = new QLineEdit();
QObject::connect(userEdit, &QLineEdit::textChanged, [userEdit](const QString &text) {if (text.contains(" ")) {userEdit->setStyleSheet("background-color: #FFC0C0;");} else {userEdit->setStyleSheet("");}
});

这段代码检查输入是否包含空格,并通过背景色变化提供视觉反馈。

三、验证反馈

验证反馈在Qt中通常用于表单输入验证,确保用户输入的数据符合预期。Qt提供了多种机制来实现验证反馈,包括QValidator类和样式表定制。

// 设置验证反馈样式
QLineEdit *validatedEdit = new QLineEdit(this);
validatedEdit->setValidator(new QIntValidator(0, 100, this));// 连接textChanged信号来提供实时反馈
connect(validatedEdit, &QLineEdit::textChanged, [validatedEdit](){QString text = validatedEdit->text();int pos = 0;QValidator::State state = validatedEdit->validator()->validate(text, pos);if (state == QValidator::Acceptable) {validatedEdit->setStyleSheet("QLineEdit { background-color: #DFF0D8; }");} elseif (state == QValidator::Intermediate) {validatedEdit->setStyleSheet("QLineEdit { background-color: #FCF8E3; }");} else {validatedEdit->setStyleSheet("QLineEdit { background-color: #F2DEDE; }");}
});

四、总结

Qt提供了多种强大的输入验证工具,包括:

  • 专用输入控件(QSpinBox, QDateEdit等)
  • 验证器(QIntValidator, QDoubleValidator, QRegularExpressionValidator)
  • 输入掩码
  • 自定义验证器

在实际开发中,应根据具体需求选择合适的验证方式,并考虑提供良好的用户反馈,使验证过程既严格又友好。

五、实战

1、效果查看

在这里插入图片描述

2、源码分享

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QValidator>
#include <QRegularExpression>class PasswordValidator : public QValidator {
public:State validate(QString &input, int &pos) const override {qDebug()<<"input:"<<input;if (input.length() < 8) {return Intermediate;}if (!input.contains(QRegularExpression("[A-Z]")) || !input.contains(QRegularExpression("[0-9]"))) {return Invalid;}return Acceptable;}
};MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow)
{ui->setupUi(this);this->ui->lineEdit->setValidator(new PasswordValidator());
}MainWindow::~MainWindow()
{delete ui;
}

在这里插入图片描述

http://www.dtcms.com/a/605380.html

相关文章:

  • GPT-5.1发布:深入解读与 GPT-5、GPT-4o 在性能与安全基准上的全面对比
  • 两台虚拟机搭建多机区块链网络
  • Vue.js栏目 - 目录一展
  • 网站采集怎么做莱芜金点子广告电子版2022最新
  • 2025 最硬核技术创新,重构 AI 感知与决策逻辑
  • flowable05外置表单和绘制流程图
  • UDP网络编程:从客户端封装到服务端绑定的深度实践
  • Arbess从初级到进阶(4) - 使用Arbess+GitLab实现React.js 项目自动化部署
  • 内网穿透技术
  • asp.net做织梦网站长沙商城网站开发
  • [免费]基于Python的深度学习豆瓣电影数据可视化+情感分析推荐系统(Flask+Vue+LSTM+scrapy)【论文+源码+SQL脚本】
  • SQL 分类
  • 微信小程序项目上传到git仓库(完整操作)
  • Vue 3响应式系统的底层机制:Proxy如何实现依赖追踪与自动更新?
  • 【MySQL】MySQL库的操作
  • 研发管理知识库(10)AWS云的核心DevOps工具介绍
  • PostgreSQL 备份导致的 Cache Pollution(缓存污染)
  • 拒绝繁杂,一款轻量,极致简洁的开源DevOps平台 - TikLab
  • 深入解析Flink会话窗口机制
  • 南京建设网站企业wordpress的伪静态
  • redis的下载和安装详解
  • 搜索智能体
  • 第27集科立分板机:东莞科立自动化流水线带领生产新变革
  • 物流网站开发实训离型剂技术支持东莞网站建设
  • Ubuntu 24.04 一站式 Flask 生产部署:pyenv + PyCharm + Gunicorn + Nginx + systemd
  • 青海省公路建设服务网站模块化网站开发
  • 开源CICD工具-Drone
  • 给予虚拟成像台尝鲜版十之二,完善支持 HTML 原型模式
  • 原生表格文本过长展示问题,参考layui长文本,点击出现文本域
  • 桂林网站建设培训asp.net网站建设