QML进阶(十二)QML中几种常见应用模式

目录

左右滑动窗口(SwipeView)

堆叠窗口(StackView)

多文档窗口(DocumentWindow)

虽然QML的界面定义非常灵活,但是我们在开发应用的时候也是有固定套路的。下面介绍一下QML应用的几种固定模式,分别是:SwipeView、StackView、DocumentWindow。SwipeView窗口是一种可以通过鼠标或者手指左右滑动来实现窗口切换的视图结构,常见于移动端应用。StackView是一种堆叠层次的窗口结构,用户可以通过按键和菜单的响应操作,切换堆叠结构中的当前窗口,在桌面端和移动端都有使用。DocumentWindow是一种多文档窗口结构,典型应用有wps、word等文档编辑应用,主要针对的是桌面端应用。下面详细介绍一下这几种窗口结构模式的使用方法。

左右滑动窗口(SwipeView)

SwipeView 模式中主窗口中的SwipeView元素相当于一个容器,用来存放子页面,子页面是基于Page根元素的窗口。初始化SwipeView的时候,我们将所有的子页面插入到容器中,然后通过左右滑动切换当前页面,实现页面之间的切换。显示效果如下:

子页面的实现方式如下:

第一页窗口

//Firstpage.qml
import QtQuick 2.9
import QtQuick.Controls 2.2
Page {
    header: Label {
        text: qsTr("第一页")
        font.pixelSize: Qt.application.font.pixe
  • 8
    点赞
  • 49
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
QML,可以通过以下几种方式调用自定义函数: 1. 直接调用:可以直接在QML文件调用自定义函数。首先,需要在QML文件导入包含自定义函数的对象。然后,可以使用该对象的实例来调用函数。例如: ``` import MyFunctions // 导入包含自定义函数的对象 ... MyFunctions.myFunction() // 调用自定义函数 ``` 2. 信号与槽机制:可以使用信号与槽机制来调用自定义函数。首先,在自定义对象定义一个信号,然后在QML文件连接该信号到一个JavaScript函数。当信号触发时,相应的JavaScript函数将被调用。例如: ``` import QtQuick 2.0 Item { signal mySignal() function myFunction() { console.log("Custom function called") mySignal() // 触发信号 } } ``` 在QML文件连接信号与JavaScript函数: ``` import MyObject // 导入包含自定义对象的模块 ... MyObject { onMySignal: { console.log("Signal received") myJavaScriptFunction() // 调用JavaScript函数 } } ``` 3. 绑定属性:可以通过绑定属性的方式来调用自定义函数。首先,在自定义对象定义一个属性,然后在QML文件将该属性绑定到一个JavaScript表达式。当属性的值发生变化时,相应的JavaScript表达式将被重新计算,从而调用自定义函数。例如: ``` import QtQuick 2.0 Item { property int myProperty: 0 function myFunction() { console.log("Custom function called") } } ``` 在QML文件绑定属性到JavaScript表达式: ``` import MyObject // 导入包含自定义对象的模块 ... MyObject { myProperty: { console.log("Property changed") myFunction() // 调用自定义函数 return 0 } } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

码农飞飞

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

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

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

打赏作者

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

抵扣说明:

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

余额充值