QML学习十七:TableView的简单使用

若该文为原创文章,转载请注明原文出处

一、TableView

TableView是Qt Quick为表格式呈现数据提供的组件。

TableView与ListView类似,相比之下多了滚动条、挑选、可调整尺寸的表头等特性,数据也是通过Model来提供,此篇使用的是内建Model。

二、TableView简单例子

定义TableViewColumn,描述表格的每一列,这是必须的,否则表格无法显示。

代码

重写main.qml

import QtQuick 2.6
import QtQuick.Window 2.2
import QtQuick.Controls 1.4
import QtQuick.Controls.Styles 1.4
import QtQuick.Layouts 1.12


Window {
    id: window
    visible: true
    width: 600
    height: 480
    title: qsTr("QML自定义组件")

    TableView {
        id: phoneTable

        anchors.fill: parent

        TableViewColumn {
            role: "name"
            title: "Name"
            width: 100
            elideMode: Text.ElideRight
        }
        TableViewColumn {
            role: "cost"
            title: "Cose"
            width: 100
        }
        TableViewColumn {
            role: "manufacturer"
            title: "Manufacturer"
            width: 140
        }


        model: ListModel {
            id: phoneModel

            ListElement {
                name: "iphone 5"
                cost: "4900"
                manufacturer: "Apple"
            }

            ListElement {
                name: "iphone 8"
                cost: "4900"
                manufacturer: "Apple"
            }

            ListElement {
                name: "iphone 6"
                cost: "4900"
                manufacturer: "Apple"
            }

            ListElement {
                name: "iphone 7"
                cost: "4900"
                manufacturer: "Apple"
            }
        }
        focus: true

    }
}



编译结果:

 显示出来效果和ListView差不多, 但增加了头,而且有默认的样式,如果不喜欢还可以定制表格样式。

三、动态增删改查 TabelView


有时你可能会想给 TableView 添加一列(一个字段),这时可以使用addColumn()方法, 其参数是 TableViewColumn,指向一个 TableViewColumn 实例,你可以动态创建这个实例。

对于前两节的示例,第三列可以这样添加进去:

Component.onCompleted: {
	var col = Qt.createQmlObject("import QtQuick 2.2\nimport QtQuick.Controls 		 1.2\nTableViewColumn{ role: \"mamifacturer\"; title: \"Manufacturer\"; width: 140; }", phoneModel);
	phoneTable.addColumn( col );
}



要想在指定位置添加一列,可以使用insertColumn(index, column)方法,index 参数指定列的索引,column 参数与 addColumn() 的参数一样。

如果你想删除某列,可以使用removeColumn(index)方法,指定列索引即可。

TableView 还提供了moveColumn(from, to),用于将一列从位置 from 移动到 to。

而如果你想给 TableView 动态添加数据,则可以通过调用 ListModel 的 append() 或 insert() 方法实现。删除数据通过 ListModel 的 clear() 或 remove() 方法实现。这些在前面介绍 ListView 的时候都已经介绍过了。

对于自定义的 Model,比如在 C++ 中实现的,则需要提供增、删、改数据的接口。
 

如有侵权,请及时联系博主删除,VX:18750903063

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

殷忆枫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值