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

新世纪建设集团网站网页制作在线生成

新世纪建设集团网站,网页制作在线生成,网站开发的质量标准,搭建wap网站在QML定义JavaScript资源一、概述二、后台代码实现文件三、共享JavaScript资源(库)一、概述 QML应用程序的一部分程序逻辑可以用 JavaScript 定义。JavaScript代码可以在QML文档中内联定义,也可以分离到单独的 JavaScript 文件中(在QML中称为JavaScript资源)。 QML…

在QML定义JavaScript资源

  • 一、概述
  • 二、后台代码实现文件
  • 三、共享JavaScript资源(库)

一、概述

QML应用程序的一部分程序逻辑可以用 JavaScript 定义。JavaScript代码可以在QML文档中内联定义,也可以分离到单独的 JavaScript 文件中(在QML中称为JavaScript资源)。
QML支持两种不同类型的JavaScript资源:后台代码实现文件和共享(库)文件。这两种JavaScript资源都可以被其他JavaScript资源导入,或者包含在QML模块中。

二、后台代码实现文件

导入到QML文档中的大多数JavaScript文件都是导入它们的QML文档的有状态实现。在这些情况下,文档中定义的QML对象类型的每个实例都需要一个单独的JavaScript对象和状态副本,以便正确地执行操作。

导入JavaScript文件时的默认行为是为每个QML组件实例提供一个唯一的、独立的副本。如果JavaScript文件没有使用.import语句导入任何资源或模块,那么它的代码将在与QML组件实例相同的范围内运行,因此可以访问和操作在该QML组件中声明的对象和属性。否则,它将有自己唯一的作用域,如果需要,QML组件的对象和属性应该作为参数传递给JavaScript文件的函数。
代码隐藏实现资源的示例如下:

  // MyButton.qmlimport QtQuick 2.0import "my_button_impl.js" as Logic // A new instance of this JavaScript resource// is loaded for each instance of Button.qml.Rectangle {id: rectwidth: 200height: 100color: "red"MouseArea {id: mouseareaanchors.fill: parentonClicked: Logic.onClicked(rect)}}// my_button_impl.jsvar clickCount = 0;   // this state is separate for each instance of MyButtonfunction onClicked(button) {clickCount += 1;if ((clickCount % 5) == 0) {button.color = Qt.rgba(1,0,0,1);} else {button.color = Qt.rgba(0,1,0,1);}}

一般来说,简单的逻辑应该在QML文件中内联定义,但更复杂的逻辑应该分离到代码背后的实现资源中,以提高可维护性和可读性。

三、共享JavaScript资源(库)

默认情况下,从QML导入的JavaScript文件与QML组件共享它们的上下文。这意味着JavaScript文件可以访问相同的QML对象并可以修改它们。因此,每次导入都必须有这些文件的唯一副本。

前一节介绍了JavaScript文件的有状态导入。然而,有些JavaScript文件是无状态的,更像是可重用库,因为它们提供了一组helper函数,不需要从导入它们的地方获取任何东西。如果使用特殊的pragma标记此类库,可以节省大量内存并加速QML组件的实例化,如下面的示例所示。

// factorial.js.pragma libraryvar factorialCount = 0;function factorial(a) {a = parseInt(a);// factorial recursionif (a > 0)return a * factorial(a - 1);// shared statefactorialCount += 1;// recursion base-case.return 1;}function factorialCallCount() {return factorialCount;}

pragma声明必须出现在除注释之外的任何JavaScript代码之前。

注意,多个QML文档可以导入“factorial.js”并调用它提供的 factorial 和 factorialCallCount 函数。JavaScript 导入的状态在导入它的QML文档之间共享,因此在从不调用 factorial 函数的QML文档中调用 factorialCallCount 函数时,它的返回值可能是非零。

例如:

// Calculator.qmlimport QtQuick 2.0import "factorial.js" as FactorialCalculator // This JavaScript resource is only// ever loaded once by the engine,// even if multiple instances of// Calculator.qml are created.Text {width: 500height: 100property int input: 17text: "The factorial of " + input + " is: " + FactorialCalculator.factorial(input)
}

由于它们是共享的,.pragma库文件不能直接访问QML组件实例对象或属性,尽管QML值可以作为函数参数传递。

http://www.hrbkazy.com/news/57442.html

相关文章:

  • wordpress免费网站国外比百度好用的搜索软件手机版
  • logo设计在线生成免费商标图片百度关键词优化查询
  • 软件开发文档的基本格式seo品牌优化整站优化
  • 国外购物平台长沙网站推广seo
  • 网站收录后才可以做排名吗百度客服电话24小时客服电话
  • 山西本地网关键词优化排名怎么做
  • 中国十大发布信息网站排名站长之家网站介绍
  • 网站建设询价单免费推广链接
  • Wordpress球队网站网站建设制作专业
  • 肇庆 网站建设巨量引擎广告投放平台代理
  • 仿威客网站百中搜
  • 用boots做网站百度关键词搜索排名多少钱
  • 建设部网站备案搜索推广渠道有哪些
  • 新网站如何做sem谷歌关键词热度查询
  • 北京做商铺的网站武汉大学人民医院光谷院区
  • 网站代备案班级优化大师使用指南
  • 网站开发日程安排怎样宣传网站
  • 网站改中文网络seo培训
  • 钓鱼网站的制作教程宽带营销案例100例
  • 无锡做网站服务重庆百度关键词推广
  • 20亿做网站郑州seo优化顾问热狗
  • 淘宝做网站找我要发票西安百度公司开户
  • 2017网站建设如何创建自己的个人网站
  • 做的门户网站怎么绑定ip地址长春网络科技公司排名
  • wordpress 收费下载seo权重优化
  • 规划电子商务网站流程app注册推广任务平台
  • 企业集团网站建设与运营外贸seo是什么意思
  • wordpress 怎么手动更新网站seo哪家公司好
  • 企业网站系统的设计与开发教程谷歌seo优化
  • 返利网站程序百度推广哪家做的最好