zoukankan      html  css  js  c++  java
  • View与Model绑定注意事项 (视图无数据显示)

    Qt 中视图与模型绑定时,模型必须使用new来创建。否则刚开始初始化的时候,视图无数据显示,或者后期视图不能随着模型的改变而改变

    具体原因:我猜测是局部变量生命周期的问题。new 的变量在堆中,除非手动释放,否则一直存在。如果不new一个Model,把Model变量放在类成员变量中也行,视图就可以正常显示数据了。

    Eorror错误的写法

    QStandardItemModel model(4,2);  
    
    model.setHeaderData(0, Qt::Horizontal, tr("Label"));  
    model.setHeaderData(1, Qt::Horizontal, tr("Quantity"));  
     
    ui.tableView->setModel(&model);  
      
    for (int row = 0; row < 4; ++row) {  
        for (int column = 0; column < 2; ++column) {  
            QModelIndex index = model.index(row, column, QModelIndex());  
            model.setData(index, QVariant((row+1) * (column+1)));  
        }  
    }  

    Right 正确的写法

    QStandardItemModel *model;  
      
    model = new QStandardItemModel(4,2);  
    ui.tableView->setModel(model);  
      
    model->setHeaderData(0, Qt::Horizontal, tr("Label"));  
    model->setHeaderData(1, Qt::Horizontal, tr("Quantity"));  
      
    for (int row = 0; row < 4; ++row) {  
        for (int column = 0; column < 2; ++column) {  
            QModelIndex index = model->index(row, column, QModelIndex());  
            model->setData(index, QVariant((row+1) * (column+1)));  
        }  
    }  

    转自:http://qimo601.iteye.com/blog/1535781

  • 相关阅读:
    Charles使用
    将当前项目加入系统变量中
    JVM之gc相关
    jdk安装
    nginx相关
    oracle带输入输出参数存储过程(包括sql分页功能)
    ajax 全局拦载处理,可加密、过滤、筛选、sql防注入处理
    01.Java关键字,常量,变量,数值类型
    01.Java数据结构和多线程
    02.MySQL.存储引擎-事务-隔离级别-锁
  • 原文地址:https://www.cnblogs.com/liushui-sky/p/5776063.html
Copyright © 2011-2022 走看看