当前位置: 首页 > news >正文

4.qml单例模式

这里写目录标题

  • js文件单例模式
  • qml文件单例模式

js文件单例模式

直接添加一个js文件到qml中
在这里插入图片描述
修改内容
在这里插入图片描述

TestA.qml

import QtQuick 2.0
import QtQuick.Controls 2.12
import "./MyWork.js" as MWItem {Row{TextField {onEditingFinished: {MW.setA(text)}}Button{onClicked: lb.text = MW.getA()}Label{id: lb}}}

main.qml

import QtQuick 2.12
import QtQuick.Window 2.12Window {visible: truewidth: 640height: 480title: qsTr("Hello World")TestA{width: parent.widthheight: 200}TestA{y:200width: parent.widthheight: 200}}

很明显使用import引入的js文件数据是不共享的,也就是他们在qml中的体现为都是个实例
在这里插入图片描述
但是有的场景我们希望我们的js文件是一个单例,也就是数据是共享的,怎么做呢?
只需要在js文件最顶部加入一行

.pragma library

既可
MyWork.js

.pragma library
var a = ""function setA(v){a = v;
}function getA() {return a;
}

总结:
有缺点,缺点就是定义的变量不会通知qml页面的变更
qml页面数据的刷新绑定的变量其实还是使用了qml的信号与槽的机制,而
js定义的变量没有ValueChanged这种信号, 故刷新不了qml页面

qml文件单例模式

而qml单例模式
需要在qml最上面加入这一行,没有逗号,跟js不一样

pragma Singleton

同时还要添加一个qmldir文件暴露此单例
在这里插入图片描述
在这里插入图片描述

总结
全局变量的使用,导致多个qml文件同时触发刷新,
哪怕那个页面不可见,大大拉低刷新性能

为此我们要确保管控好这些变量,

尽量不要让他们本身成功绑定值或者所在的方法成为绑定值(有值),
否则一旦此值变动都会触发左值的更新

    Row{TextField {onEditingFinished: {TestB.setName(text)}}Text {visible:  falsetext: {console.log("11111")return TestB.name}}Text {text: {console.log("22222")return TestB.name}}}

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Windows系统通过部署wsl + Goland进行跨平台开发
  • 劳特巴赫ICD调试器CMM调用烧录框架固件研究之C语言版本
  • Android 中使用高德地图实现根据经纬度信息画出轨迹、设置缩放倍数并定位到轨迹路线的方法
  • 浅谈人工智能之基于HTTP方式调用本地QWen OPenAI接口(Java版)
  • Qt_按钮类控件
  • 今日leetcode 349.两个数组的交集
  • Qt 类型选择器和类选择器的区别
  • C++学习笔记(30)
  • 【网络】传输层协议TCP
  • SpringBoot+thymeleaf竞赛报名系统
  • 解决【WVP服务+ZLMediaKit媒体服务】加入海康摄像头后,能发现设备,播放/点播失败,提示推流超时!
  • [机器学习]决策树
  • 24年蓝桥杯及攻防世界赛题-MISC-3
  • Jenkins 构建后操作(Send build artifacts over SSH)
  • Codes 开源研发项目管理平台——敏捷测试管理创新解决方案
  • (十五)java多线程之并发集合ArrayBlockingQueue
  • 【407天】跃迁之路——程序员高效学习方法论探索系列(实验阶段164-2018.03.19)...
  • 【附node操作实例】redis简明入门系列—字符串类型
  • avalon2.2的VM生成过程
  • C++11: atomic 头文件
  • js作用域和this的理解
  • Object.assign方法不能实现深复制
  • php中curl和soap方式请求服务超时问题
  • PV统计优化设计
  • python_bomb----数据类型总结
  • WebSocket使用
  • 从 Android Sample ApiDemos 中学习 android.animation API 的用法
  • 力扣(LeetCode)357
  • 聊聊directory traversal attack
  • 如何打造100亿SDK累计覆盖量的大数据系统
  • 软件开发学习的5大技巧,你知道吗?
  • 小程序01:wepy框架整合iview webapp UI
  • nb
  • ​14:00面试,14:06就出来了,问的问题有点变态。。。
  • ​2020 年大前端技术趋势解读
  • #《AI中文版》V3 第 1 章 概述
  • #FPGA(基础知识)
  • #if等命令的学习
  • #前后端分离# 头条发布系统
  • (Redis使用系列) Springboot 使用redis的List数据结构实现简单的排队功能场景 九
  • (二)测试工具
  • (分类)KNN算法- 参数调优
  • (深入.Net平台的软件系统分层开发).第一章.上机练习.20170424
  • (十二)python网络爬虫(理论+实战)——实战:使用BeautfulSoup解析baidu热搜新闻数据
  • (四) Graphivz 颜色选择
  • (转) Face-Resources
  • (转)树状数组
  • (转载)深入super,看Python如何解决钻石继承难题
  • ******之网络***——物理***
  • .NET 5种线程安全集合
  • .NET 8.0 发布到 IIS
  • .NET C#版本和.NET版本以及VS版本的对应关系
  • .NET Core MongoDB数据仓储和工作单元模式封装
  • .Net Core 中间件验签
  • .net core使用EPPlus设置Excel的页眉和页脚