0

我的项目中有三个 .cpp 文件:
在此处输入图像描述

现在,我重新实现了 QSqlQueryModel 以使其可编辑,这意味着我重新实现了函数 QSqlQueryModel::setData() 和函数 QSqlQueryModel::flags() 并且我使用 QTableview 来显示数据。
在重新实现的函数 QSqlQueryModel::setData() 的最后,有一个刷新步骤再次将数据填充到模型中:

bool ScoreModel::setData(const QModelIndex &index, const QVariant &value, int /* role */)
{
   if (index.column() == 0 || index.column() == 11)
        return false;

    QModelIndex primaryKeyIndex = QSqlQueryModel::index(index.row(), 0);
    int id = data(primaryKeyIndex).toInt();
    qDebug()<<"id:"<<id;
    clear();

    bool ok;
    switch(index.column()){
    case 1:
        ok = setYear(id,value.toString());
        break;
    case 2:
        ok = setStudentName(id,value.toString());
        break;
    ...
    case 10:
        ok = setTeacherRemark(id,value.toString());
        break;
    default:
        ok = false;
    }
    refresh();// <---
    return ok;
}


void ScoreModel::refresh()
{
    qDebug()<<"sqlToQueryScore in refresh:"<<MainWindow::sqlToQueryScore;
    setQuery(MainWindow::sqlToQueryScore);
    setHeaderData(0, Qt::Horizontal, tr("序号"));
    setHeaderData(1, Qt::Horizontal, tr("年份"));
    ...
    setHeaderData(11, Qt::Horizontal, tr("数据插入时间"));
}

但我在 mainwindow.cpp 中用以下代码装饰了 tableView(可以引用 ui->tableView):

ui->tableView->setModel(scoreModel);
//ui->tableView->setEditTriggers(QAbstractItemView::DoubleClicked);
ui->tableView->verticalHeader()->hide();
ui->tableView->resizeColumnsToContents();
ui->tableView->resizeRowsToContents();
//ui->tableView->setSelectionMode(QAbstractItemView::SingleSelection);
ui->tableView->setSelectionBehavior(QAbstractItemView::SelectRows);
ui->tableView->horizontalHeader()->setStretchLastSection(true);  

为了保持tableView外观的一致性,我也想在刷新步骤中进行这样的操作。
在我有限的 Qt/C++ 经验中,我无法有效地处理它。我在网上找了很久。但是没有用。请帮助或尝试给出一些想法如何实现这一点。谢谢!

4

1 回答 1

0

MVC 模式(或 Qt 术语中的Model/View Programming)的想法是让您的模型与您的视图控制器分离。Sloppy 说:“模型应该只处理数据本身,不知道它会如何显示。” 但我绝对建议你扔掉上面的链接。

您的问题的可能解决方案是在您的方法中发出一个信号ScoreModel::refresh(),在您的视图控制器(在您的情况下mainwindow.cpp)中定义并连接相应的插槽方法以刷新您的表格视图,参见。信号和插槽

于 2018-06-11T15:43:50.610 回答