1、pagestack进行页面调整的时候,需要对页面状态做一些跟踪:

Stack.onStatusChanged: {

if (Stack.status == Stack.Active) { //可以判断是否跳转完成

isPageReady = true

} else if (Stack.status == Stack.Inactive) {

isPageReady = false

}

}

2、qml中信号的使用

A.qml 中有一个函数实现

//选择案件后的回调事件

function setCaseInfo(name,legalid){

var info = {};

info.name = name;

info.legalid = legalid;

    caseText.text = name;
downloadRec.caseId = legalid;
var result = Storage.insert("caseinfo",JSON.stringify(info));
}

动态创建一个页面B并获取返回值:

MouseArea{

id : caseArea

anchors.fill: parent

onClicked: {

var content = Case.createElement("../caseStudy/AddCaseWin.qml",null);

content.caseselected.connect(setCaseInfo);

}

}

B页面有一个信号

signal caseselected(string name,int caseid)

B页面调用C组件:

ListView{

anchors.fill: parent

spacing: 25*screen.scale

clip: true

delegate: AddCaseItem{}

model:caseListModel

orientation:ListView.Horizontal

}

C组件则实现具体的参数透传:

MouseArea{

anchors.fill: parent

onClicked: {

caseselected(desction,legalid);

closeWin();

}

}

3.设置内部元素

default property alias contents: contents.data

    Item {
id: contents width: flickable.width
height: autoFlick ? childrenRect.height : flickable.height
}

根据官方的意思:

data是默认属性,相当于子控件。childrenRect是用来访问子元素的宽高等信息

4.遍历指定类型的元素:

function getFlickableChild(item) {

if (item && item.hasOwnProperty("children")) {

for (var i=0; i < item.children.length; i++) {

var child = item.children[i];

if (internal.isVerticalFlickable(child)) {

if (child.anchors.top === page.top || child.anchors.fill === page) {

return item.children[i];

}

}

}

}

return null;

}

如何构建qml的模版:

They use default property alias ... to alias the child items to any property of any item. If you don't want to alias the children but give the alias property a name, just remove default. (Literal children are per QML definition the value of the default property.)

Item {

id: button

default property alias contents: placeholder.children

anchors.fill: parent

Rectangle {
anchors.fill: parent
radius: 10
color: "gray" Item {
id: placeholder <-- where the placeholder should be inserted
}
}

}

一个更具体的例子:

Dialog {

id: actionableDialog

title: "Change Text"

hasActions: true

    TextField {
id: optionText
text: currentText
width: parent.width
placeholderText: "New Option to Confirm"
} onAccepted: {
currentText = optionText.text
}
}

Dialog.qml

PopupBase {

id: dialog

overlayLayer: "dialogOverlayLayer"
overlayColor: Qt.rgba(0, 0, 0, 0.3) opacity: showing ? 1 : 0
visible: opacity > 0 width: Math.max(minimumWidth,
content.contentWidth + 2 * contentMargins) height: Math.min(units.dp(350),
headerView.height + units.dp(32) +
content.contentHeight +
content.topMargin +
content.bottomMargin +
buttonContainer.height) property int contentMargins: units.dp(16) property int minimumWidth: units.dp(270) property alias title: titleLabel.text
property alias text: textLabel.text /*!
\qmlproperty Button negativeButton The negative button, displayed as the leftmost button on the right of the dialog buttons.
This is usually used to dismiss the dialog.
*/
property alias negativeButton: negativeButton /*!
\qmlproperty Button primaryButton The primary button, displayed as the rightmost button in the dialog buttons row. This is
usually used to accept the dialog's action.
*/
property alias positiveButton: positiveButton property string negativeButtonText: "Cancel"
property string positiveButtonText: "Ok"
property alias positiveButtonEnabled: positiveButton.enabled property bool hasActions: true default property alias dialogContent: column.data

Flickable {

id: content

        contentWidth: column.implicitWidth
contentHeight: column.height
clip: true anchors {
left: parent.left
right: parent.right
top: headerView.bottom
topMargin: units.dp(8)
bottomMargin: units.dp(-8)
bottom: buttonContainer.top
} interactive: contentHeight + units.dp(8) > height
bottomMargin: hasActions ? 0 : units.dp(8) Rectangle {
Column {
id: column
anchors {
left: parent.left
margins: contentMargins
} width: content.width - 2 * contentMargins
spacing: units.dp(16)
}
}
}

}

qml 一些知识点的更多相关文章

  1. QML学习(一)——<简要概念知识点>

    转载:https://www.cnblogs.com/dengyg0710/p/10644936.html 1.一个 QML 文档有且只有一个根元素. 2.QML 元素名后所有内容使用 {} 包围起来 ...

  2. qml: QtChart横纵轴label设置;

    在qml中,使用ChartView作为图表展示区域, 但是并没有给定接口用来设置xlabel,ylabel. 没得办法,只能采用笨方案: (我的方法如下) import QtQuick 2.0 imp ...

  3. ASP.NET Core 中的那些认证中间件及一些重要知识点

    前言 在读这篇文章之间,建议先看一下我的 ASP.NET Core 之 Identity 入门系列(一,二,三)奠定一下基础. 有关于 Authentication 的知识太广,所以本篇介绍几个在 A ...

  4. ASP.NET MVC开发:Web项目开发必备知识点

    最近加班加点完成一个Web项目,使用Asp.net MVC开发.很久以前接触的Asp.net开发还是Aspx形式,什么Razor引擎,什么MVC还是这次开发才明白,可以算是新手. 对新手而言,那进行A ...

  5. UWP开发必备以及常用知识点总结

    一直在学UWP,一直在写Code,自己到达了什么水平?还有多少东西需要学习才能独挡一面?我想对刚接触UWP的开发者都有这种困惑,偶尔停下来总结分析一下还是很有收获的! 以下内容是自己开发中经常遇到的一 ...

  6. C#高级知识点&(ABP框架理论学习高级篇)——白金版

    前言摘要 很早以前就有要写ABP高级系列教程的计划了,但是迟迟到现在这个高级理论系列才和大家见面.其实这篇博客很早就着手写了,只是楼主一直写写停停.看看下图,就知道这篇博客的生产日期了,谁知它的出厂日 ...

  7. lucene 基础知识点

    部分知识点的梳理,参考<lucene实战>及网络资料 1.基本概念 lucence 可以认为分为两大组件: 1)索引组件 a.内容获取:即将原始的内容材料,可以是数据库.网站(爬虫).文本 ...

  8. DoraCMS 源码知识点备注

    项目需要研究了下DoraCMS这款开源CMS,真心做的不错:).用的框架是常用的express 4 + mongoose,代码也很规范,值得学习. 源码中一些涉及到的小知识点备注下: https:// ...

  9. atitit 商业项目常用模块技术知识点 v3 qc29

    atitit 商业项目常用模块技术知识点 v3 qc29 条码二维码barcodebarcode 条码二维码qrcodeqrcode 条码二维码dm码生成与识别 条码二维码pdf147码 条码二维码z ...

随机推荐

  1. Servlet学习

    编写Servlet应该注意的一些细节: 1: 由于客户端是通过URL地址访问web服务器中的资源,所以Servlet程序若想被外界访问,必须把servlet程序映射到一个URL地址上,这个工作在web ...

  2. [转]-Android Studio 快捷键整理分享-SadieYu

    文章编辑整理:Android Studio 中文组 - SadieYu Alt+回车 导入包,自动修正 Ctrl+N   查找类 Ctrl+Shift+N 查找文件 Ctrl+Alt+L  格式化代码 ...

  3. ie8不支持transform: translateY,ie9支持不友好

    transform: translateY(0);  ie8 不支持这个属性  但是我觉得用css实现的效果特好 特自然 也许是我的脚本写的不够完善 呵呵    现在我希望其他 主流的浏览器应用CSS ...

  4. iOS - UICollectionViewController

    前言 NS_CLASS_AVAILABLE_IOS(6_0) @interface UICollectionView : UIScrollView @available(iOS 6.0, *) pub ...

  5. oracle 查看锁表情况并处理锁表

    /* *locked *query locked object and analyse reason,kill it * */ select 'alter system kill session '' ...

  6. 刻录DVD_目录

    1.down.52pojie.cn (20160701) (1 in 5) 工具 2.down.52pojie.cn (20160701) (2 in 5) Android VM 6/7 3.down ...

  7. parseInt 的第二个参数

    ["1","2","3"].map(parseInt) //[1,NaN,NaN] ["1","2" ...

  8. apiCloud中图片裁剪模块FNImageClip的使用

    思路 1.获取需裁剪图片的地址 2.跳转到裁剪页面 3.裁剪成功返回新图片地址 4.替换原有图片地址 增加修饰和事件 str += '<li class="tu image" ...

  9. js 的小效果---->选项卡

    js选项卡   <!doctype html> <html> <head> <meta charset="utf-8"> <t ...

  10. 每一个可以移动的棋子都要移动——Every-SG 游戏

    先看一个问题 HDU 3595 GG and MM (Every_SG博弈) 题目有N个游戏同时进行,每个游戏有两堆石子,每次从个数多的堆中取走数量小的数量的整数倍的石子.取最后一次的获胜.并且N个游 ...