QML Loader 属性传递问题?



  • Loader{
    property var data: JSON.parse('{"fileName":"%1","index":"%2"}'.arg(fileName).arg(index))
    property var fileName1:data.fileName
    sourceComponent: fileListRect.editRect
    Component.onCompleted: {
    console.log(fileName1)
    }

    }

    1. Loader 可以把 fileName1 传给 sourceComponent 在 sourceComponent可以直接使用 fileName1
    2. Loader 能把 data 传给 sourceComponent,在 sourceComponent可以直接使用 data.fileName,data.index?


  • @MOMO 这里有一个隐含的问题。QML在实例化的时候,你如何判断data先被初始化还是sourceComponent先被初始化?

    你可以尝试一下。一般来说,最后声明的成员最先被初始化。
    这样的话,你可能要调换一下位置。

    还有其它办法,像这样的操作:

    property var data: JSON.parse('{"fileName":"%1","index":"%2"}'.arg(fileName).arg(index))
    

    不直观而且容易出错,为何不用JSON直接初始化呢?



  • @jiangcaiyang 说:

    我换了 变量名,把data改为 styleData可以了styleData.fileName,,可能是 data 这个变量名的问题?????



  • @MOMO 不会吧。这个例子和style没有什么关系啊。


Log in to reply
 

走马观花

最近的回复

  • E

    是不是好久都没有人了,站主找到工作了,还是说划水了

    read more
  • 请问一下如果原Qt桌面软件支持拖拽外部文件进去(比如把在用资源管理器里的一张图片拖拽到软件界面上就会显示这张图片),转成Webassembly之后这种拖拽操作还是否有效?劳烦大佬帮我试试看,可以的话我就学QML了

    read more
  • H
    Toou 2D 拿来即用,为简单而生。

    简称T2D,是一款采用自身模块规范编写的轻量级UI框架,遵循Qt书写与组织形式门槛极低无需深入学习简单易用可拿来即用,丰富的控件模块适合界面的快速开发,让程序人员拥有更多的精力来实现业务逻辑与算法。

    统一交互规范,丰富的Ui控件几十种常用控件放弃了Qt Controls 及 Controls 2 来提高性能。

    完善的主题系统,业务逻辑与界面主题设计分离,可通过简单修改变量自定义主题皮肤。灵活的多主题皮肤绑定机制、在不需要重启App即实现一键换肤

    ini皮肤配置规则与每一个控件融合。可在应用内配置也可在应用外动态扩展配置。

    框架自动化安装支持动态库、静态库多模式编译。使用方便更安全更自由。

    提供丰富Demo、全面的帮助文档,Api查阅快速方便。项目必备开源框架!

    已经集成最新版 Font Awesome 4.7

    开源地址:https://github.com/ShowFL/Toou-2D

    read more
  • 刚刚毕业,工作用QT开发,以后有问题多多请教各位前辈😬 抱拳了。

    read more

关注我们

微博
QQ群