C++ 如何更改QT中信号和插槽的计时?
我正在创建一个管理学生信息的程序。目前我有一个tableview和一个add按钮,当我点击add按钮时,会弹出一个新对话框,提示用户添加新学生。我的意图是创建一个到对话框的信号和插槽连接,这样每当按下ok按钮时,我的tableview就会刷新(我使用的是SQLITE)。但是,现在的问题是,在我看来,在调用refreshwindow函数之后,数据库正在更新,因此,当我调用refreshwindow函数时,数据库尚未更新。我不确定这是否是安全的问题,但这就是我的想法 以下是一些代码: 当我点击add按钮时C++ 如何更改QT中信号和插槽的计时?,c++,qt,signals,C++,Qt,Signals,我正在创建一个管理学生信息的程序。目前我有一个tableview和一个add按钮,当我点击add按钮时,会弹出一个新对话框,提示用户添加新学生。我的意图是创建一个到对话框的信号和插槽连接,这样每当按下ok按钮时,我的tableview就会刷新(我使用的是SQLITE)。但是,现在的问题是,在我看来,在调用refreshwindow函数之后,数据库正在更新,因此,当我调用refreshwindow函数时,数据库尚未更新。我不确定这是否是安全的问题,但这就是我的想法 以下是一些代码: 当我点击add
void viewStudents::on_addStudent_clicked()
{
studentWindow = new studentManagement(username,this);
QObject::connect(studentWindow,SIGNAL(accepted()),this, SLOT(refreshwindow()));
studentWindow->show();
}
我的刷新窗口功能
void viewStudents::refreshwindow()
{
QSqlQueryModel *modal = new QSqlQueryModel();
QSqlDatabase tempdb = QSqlDatabase::addDatabase("QSQLITE");
tempdb.setDatabaseName("accounts.db");
if(tempdb.open()){
QSqlQuery tempquery;
tempquery.exec("SELECT firstname, lastname, DOB, Day_of_lessons, Start_date, Price_per_lesson, Length_of_lessons from studentList WHERE teacher = '"+username+"';");
modal->setQuery(tempquery);
ui->tableView->setModel(modal);
ui->tableView->resizeColumnsToContents();
ui->tableView->resizeRowsToContents();
tempdb.close();
}
else{
QMessageBox::warning(this,"Error","Something unexpected has happened.");
}
}
我的添加学生对话框
studentManagement::studentManagement(QString username, QWidget *parent) :
QDialog(parent),
ui(new Ui::studentManagement)
{
this->username = username;
ui->setupUi(this);
QFont information_font = ui->informationLabel->font();
information_font.setPointSize(14);
information_font.setBold(true);
ui->informationLabel->setFont(information_font);
ui->startdate->setMinimumDate(QDate::currentDate());
ui->dayOfLessonsBox->addItem("Monday");
ui->dayOfLessonsBox->addItem("Tuesday");
ui->dayOfLessonsBox->addItem("Wednesday");
ui->dayOfLessonsBox->addItem("Thursday");
ui->dayOfLessonsBox->addItem("Friday");
ui->dayOfLessonsBox->addItem("Saturday");
ui->dayOfLessonsBox->addItem("Sunday");
}
studentManagement::~studentManagement()
{
delete ui;
}
void studentManagement::on_buttonBox_accepted()
{
QString firstname = ui->firstname->text();
QString lastname = ui->lastname->text();
QString DOB = ui->dateofbirth->text();
QString dayOfLessons = ui->dayOfLessonsBox->currentText();
QString startdate = ui->startdate->text();
QString pricing = ui->pricing->text();
QString lengthoflessons = ui->lengthoflessons->text();
QSqlDatabase mydb = QSqlDatabase::addDatabase("QSQLITE");
mydb.setDatabaseName("accounts.db");
if(!mydb.open())QMessageBox::warning(this,"File Not Found Error", "The database file cannot be find.");
else{
QSqlQuery query;
if(query.exec("INSERT INTO studentList VALUES('"+firstname+"', '"+lastname+"', '"+DOB+"', '"+dayOfLessons+"', '"+startdate+"', '"+pricing+"', '"+lengthoflessons+"', '"+username+"');")){
mydb.close();
}
}
}
如果有人能帮我一点忙或者给我一些建议,我会非常感激的 首先您应该在构造函数中使用您的
connect
语句,或者每次调用\u addStudent\u clicked()时,都会执行一个新的connect,它不会产生错误,但完全没有必要
其次,当我们向列表中添加记录时,我们希望确保列表立即被刷新,因此它需要在insert
语句之后
第三,Qt非常智能,可以找到您想要创建的隐式连接,如果您正在使用\u something\u sometevent()上的一般形式创建函数,那么它将自动查找对象/类(类型为QObject
)命名为something
并将其信号someevent
连接到this
和上的
作为插槽。因此,编写类似于thisobject::on_something\u sometevent(){}
的函数将自动呈现为:
QObject::connect(something, SIGNAL(someevent()), this, SLOT(on_something_someevent()));
这非常方便,但它可能尝试创建不需要的连接
,或者至少引发警告或错误
最后,不要忘记在头文件中使用公共插槽:
定义插槽。公共部分是必需的,否则您将获得访问冲突错误,因为Qt framework无法(从另一个对象)调用插槽函数
这是你的代码的纠正形式,我认为可以做这项工作(我没有你的.UI或.h文件,既不是你的两个类的完整来源,也不是你的代码>主())/代码>函数,所以请考虑这是一个部分来源,我希望传达要点)
您需要在构造函数中加入connect,并完全消除第一个函数。将“刷新”和“显示”放在“打开”按钮框的末尾。如果你想不出答案,我会发布答案。哦,你需要更改连接参数。将您的按钮点击信号连接到on_buttonBox_接受的插槽(将其公开:如果不是,则在标题中)@Iman非常感谢!这很有道理!如果可能的话,你能把答案贴出来吗?我的连接部分有点问题。我真的很感激!阅读有关编译时间检查连接语法@ JNYN21099抱歉延误,我是在中间移动到一个新的地方。我谦虚地建议您阅读Qt文档和youtube上的官方视频。祝你好运
void viewStudents::refreshwindow()
{
QSqlQueryModel modal = QSqlQueryModel::QSqlQueryModel();
QSqlDatabase tempdb = QSqlDatabase::addDatabase("QSQLITE");
tempdb.setDatabaseName("accounts.db");
if (tempdb.open()) {
QSqlQuery tempquery;
tempquery.exec("SELECT firstname, lastname, DOB, Day_of_lessons, Start_date, Price_per_lesson, Length_of_lessons from studentList WHERE teacher = '" + username + "';");
modal->setQuery(tempquery);
ui->tableView->setModel(modal);
ui->tableView->resizeColumnsToContents();
ui->tableView->resizeRowsToContents();
tempdb.close();
}
else {
QMessageBox::warning(this, "Error", "Something unexpected has happened.");
}
}
studentManagement::studentManagement(QString username, QWidget *parent) :
QDialog(parent),
ui(new Ui::studentManagement)
{
this->username = username;
ui->setupUi(this);
QFont information_font = ui->informationLabel->font();
information_font.setPointSize(14);
information_font.setBold(true);
ui->informationLabel->setFont(information_font);
ui->startdate->setMinimumDate(QDate::currentDate());
ui->dayOfLessonsBox->addItem("Monday");
ui->dayOfLessonsBox->addItem("Tuesday");
ui->dayOfLessonsBox->addItem("Wednesday");
ui->dayOfLessonsBox->addItem("Thursday");
ui->dayOfLessonsBox->addItem("Friday");
ui->dayOfLessonsBox->addItem("Saturday");
ui->dayOfLessonsBox->addItem("Sunday");
// This connect statment could be quit unnecessary as Qt will create it automatically
// Since you have created the function name as it is expected by Qt (on_class_event)
QObject::connect(addStudent, SIGNAL(clicked()), this, SLOT(on_addStudent_clicked()));
}
studentManagement::~studentManagement()
{
delete ui;
}
void studentManagement::on_addStudent_clicked()
{
QString firstname = ui->firstname->text();
QString lastname = ui->lastname->text();
QString DOB = ui->dateofbirth->text();
QString dayOfLessons = ui->dayOfLessonsBox->currentText();
QString startdate = ui->startdate->text();
QString pricing = ui->pricing->text();
QString lengthoflessons = ui->lengthoflessons->text();
QSqlDatabase mydb = QSqlDatabase::addDatabase("QSQLITE");
mydb.setDatabaseName("accounts.db");
if (!mydb.open())
{
QMessageBox::warning(this, "File Not Found Error", "The database file cannot be find.");
}
else
{
QSqlQuery query;
if (query.exec("INSERT INTO studentList VALUES('" + firstname + "', '" + lastname + "', '" + DOB + "', '" + dayOfLessons + "', '" + startdate + "', '" + pricing + "', '" + lengthoflessons + "', '" + username + "');"))
mydb.close();
}
studentWindow = new studentManagement(username, this);
studentWindow->show();
viewStudents::refreshwindow();
// OR
// define refreshwindow as a public slot and emit a signal from here
emit(viewStudents::refreshwindow());
}