当前位置:   article > 正文

QT:QML中使用Loader加载界面_qt qml 加载插件 页面

qt qml 加载插件 页面

 

目录

一.介绍

二.实现

三.效果展示

四.代码


一.介绍

QML中使用Loader加载界面,可以带来诸多好处,如提高应用程序的启动速度、动态地改变界面内容、根据条件加载不同的组件、更有效地使用内存以及帮助分割应用逻辑等

1.延迟加载:QML Loader允许开发者在需要时才加载组件,而不是在应用程序启动时一次性加载所有组件。这样可以加快应用程序的启动时间,因为它只需要初始化用户当前需要看到的部分。

2.动态内容:Loader可以在运行时加载不同的QML文件或组件,这样可以根据用户的操作或应用程序的状态来改变界面的内容。

3.条件加载:Loader可以根据条件判断来加载不同的组件。例如,你可以基于设备的屏幕尺寸或者是操作系统来加载不同的用户界面组件。

4.内存管理:由于 Loader只加载当前需要的组件,因此可以更有效地使用内存。不需要的组件可以被卸载,这样那些内存就可以用于其他目的。

5.分割应用逻辑:使用 Loader 可以帮助你把应用程序的不同部分分割成小的、可管理的单元,这样有助于维护和更新应用程序。

二.实现

1.定义了一个名为m_source的变量,它是一个var类型的变量,用于存储当前选中的组件。通过调用setLayer函数,可以根据传入的索引来设置m_source的值。

2.定义了一个名为onChangeWidget的函数,当工具栏中选中不同的选项时,会调用这个函数,并传入当前选中的索引。这个函数会调用setLayer函数,来设置当前选中的组件。

3.组件可以在其他地方被引用,并在运行时动态加载。loginComponet被引用为m_source的一个值,并通过Loader组件动态加载。在Login组件被加载后,可以通过_login来访问该组件的属性和函数。

4.在Flickable组件中,使用了一个Loader组件,用于加载当前选中的组件。当m_source的值发生变化时,Loader组件会自动加载相应的组件。

三.效果展示

点击左上角不同按钮,切换界面

四.代码

  1. import QtQuick 2.7
  2. import QtQuick.Window 2.2
  3. import QtQuick.Controls 1.4
  4. Window {
  5. visible: true
  6. width: 1400
  7. height: 800
  8. title: qsTr("Hello World")
  9. property var m_source:setLayer()
  10. function setLayer(index){
  11. switch(index){
  12. case 0:
  13. m_source = loginComponet
  14. break
  15. case 1:
  16. m_source = modifyIDComponet
  17. break
  18. case 2:
  19. m_source = modifyPasComponet
  20. break
  21. case 3:
  22. m_source = sqlComponet
  23. break
  24. default:
  25. m_source = loginComponet
  26. break
  27. }
  28. return m_source
  29. }
  30. QMLreadini{
  31. id:_QMLreadini
  32. }
  33. MainToolBar{
  34. id: _toolbar
  35. anchors.top:parent.top
  36. width: parent.width
  37. height: 60
  38. onChangeWidget: {
  39. setLayer(_index)
  40. }
  41. }
  42. Component {
  43. id: loginComponet
  44. Login{
  45. id:_login
  46. anchors.centerIn: parent
  47. }
  48. }
  49. Component {
  50. id: sqlComponet
  51. SqlLite{
  52. id:_SqlLite
  53. }
  54. }
  55. Component {
  56. id: modifyIDComponet
  57. ModifyID{
  58. id:_ModifyID
  59. anchors.centerIn: parent
  60. }
  61. }
  62. Component {
  63. id: modifyPasComponet
  64. ModifyPas{
  65. id:_ModifyPas
  66. anchors.centerIn: parent
  67. }
  68. }
  69. Flickable{
  70. anchors.top: _toolbar.bottom
  71. anchors.bottom: parent.bottom
  72. anchors.topMargin: 30
  73. anchors.left: parent.left
  74. anchors.right: parent.right
  75. Rectangle{
  76. id: mainRect
  77. anchors.fill: parent
  78. color: "transparent"
  79. Loader {
  80. id: deferedload
  81. anchors.top: mainRect.top
  82. anchors.left: mainRect.left
  83. anchors.right: mainRect.right
  84. sourceComponent: m_source
  85. }
  86. }
  87. }
  88. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/695050
推荐阅读
相关标签
  

闽ICP备14008679号