玉溪市网站建设,wordpress重写页面样式,云南能投基础设施投资开发建设有限公司网站,wordpress自动发文章在QML定义JavaScript资源一、概述二、后台代码实现文件三、共享JavaScript资源(库)一、概述
QML应用程序的一部分程序逻辑可以用 JavaScript 定义。JavaScript代码可以在QML文档中内联定义#xff0c;也可以分离到单独的 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: redMouseArea {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值可以作为函数参数传递。