1. 常用的窗口标志设置
- 设置窗口无标题栏
// 设置窗口无标题栏
this->setWindowFlags(Qt::CustomizeWindowHint);
- 设置窗口无边框
// 设置窗口无边框
setWindowFlags(Qt::FramelessWindowHint);
- 设置窗口置顶
// 设置窗口置顶
setWindowFlags(Qt::FramelessWindowHint|Qt::WindowStaysOnTopHint);
2. 输入 QLineEdit
2.1 清空功能:
- LineEdit组件,设置见面勾选下面选项即可实现清空功能
- 生效后,右边会出现一个 × ,点击就能清空内容了
2.2 文本框提示功能
- 只需要在如下选项中添加提示信息,即可,以“手机号/邮箱”为例
- 效果:
2.3 文本框记忆功能(显示曾输入的内容)
- 这个功能可以使用一个按钮触发,比如我们创建一个“登录”按键
- 用转到槽去创建函数
- 接下来我们需要用到一个 setCompleter
- 第一步:头文件里需要设置一个 historyList 来存储变量
- 第二步:常规操作,记得引入最上面引入 QCompleter
#include <QCompleter>
void Widget::on_pushButton_clicked()
{
QCompleter *completer = new QCompleter(historyList);
ui->lineEdit->setCompleter(completer);
}
- 第三步:添加用户输入信息
void Widget::on_pushButton_clicked()
{
QString text = ui->lineEdit->text().trimmed();//第三步:添加用户输入信息
QCompleter *completer = new QCompleter(historyList);
ui->lineEdit->setCompleter(completer);
}
- 第四步:把输入信息添加到historyList中
先判断一下是否historyList中已经包含这个文本了(如果包含就不需要添加)
void Widget::on_pushButton_clicked()
{
QString text = ui->lineEdit->text().trimmed();
// 判断是否historyList中已经包含这个文本了
if(historyList.contains(text)){
return; // 如果包含就不需要添加
}
// 把text内容添加到historyList中
historyList<<text;
QCompleter *completer = new QCompleter(historyList);
ui->lineEdit->setCompleter(completer);
}
- 效果:
输入号码点击登录
输入前几位就会提示你之前输入过的历史记录
2.4 密码输入模式
- 输入框组件,选择Password即可
- 第二个选项:NoEcho 就是输入密码的时候就不会显示,什么都不显示,有点像linux用户输入密码的场景
- 最后一个选项 PasswordEchoOnEdit 是用户输入的时候可以看到密码,但是切换输入框以后就恢复成了密码的圆点格式。
总结: 四种输入模式是一个从弱到强的过程。
2.5 验证器校验
- 正则验证器
需要一个正则表达式
表达式含义如下,这里我们选择只能输入数字:
代码如下:
QRegExp reg("\\d+"); // 创建一个正则表达式reg,传给下面的QRegExpValidator()
QRegExpValidator* validator = new QRegExpValidator(reg);
ui->lineEdit->setValidator(validator);//setValidator()
- 效果:此时输入框只能输入数字,不能输入字母