QML组件之间的通信方案(暴露子组件)

在项目里,经常有时候想让组件之间通信触发,但总是出现类似TypeError: Value is undefined等报错,下面写一下目前我使用的解决方案:

一、property alias

  • 概念:即别名机制,可以将某一组件或属性暴露给外部调用

    • alia:本身就译为别名
  • 特点:本质是引用绑定,为内部对象创建一个对外的引用接口

  • 场景:目前我使用于暴露组件id,以供跨组件使用

  • 举例:

    • 先在组件顶部使用property alias暴露子组件id
    c 复制代码
    //EnterPage.qml
    Rectangle{
        id:toenterRec
        //...
    
        property alias enterEmailTxtFld: emailTxtFld
        property alias enterPasswdTxtFld: passwdTxtFld
    
    	TextField{
            id:emailTxtFld
            //...
        }
    
    	TextField{
            id:passwdTxtFld
            //...
        }
    }
    • 然后再在需要通信的组件中创建出该组件的实例,就可以直接使用别名进行通信调用了
    c 复制代码
    //LoginPage.qml
    Rectangle{
        id:backRec
        //...
    	
    	MouseArea{
            z:0                          
            anchors.fill: parent
            onPressed: (mouse)=>{
                    toenterRec.enterEmailTxtFld.focus=false
                    toenterRec.enterPasswdTxtFld.focus=false
                }
            }
        }
    
    	EnterPage{
            id:toenterRec
            //...
    	}
    }
    • 我这边是用来实现点击背景取消所有的焦点事件,但其实后续废弃了,改成了直接封装函数使用

二、封装函数

在后续的开发中,我舍弃了别名的方案,改为了封装函数提供外部组件使用

在询问ai时,说是直接暴露组件对于封装性来说不太好,故改此方案

  • 举例:

    • 在当前组件中封装好工具函数
    c 复制代码
    //EnterPage.qml
    Rectangle{
        id:toenterRec
        //...
    
        function clearFocus(){
            emailTxtFld.focus=false
            passwdTxtFld.focus=false
        }
    }
    • 在通信组件中创建好实例后,直接调用此函数
    c 复制代码
    //LoginPage.qml
    Rectangle{
        id:backRec
        //...
    
        MouseArea{
            z:0  
            anchors.fill: parent
            onPressed: (mouse)=>{
            		//...
            		
                    //调用函数
                    toenterRec.clearFocus()
                }
            }
        }
    }

三、结语

虽然最后看来property alias并没有发挥实质性作用,但也是实践学习路上的过程,也先暂且记录。

目前的方案肯定还不够完善,但也是当下用的顺手便捷的了,以供之后补充更新吧...

相关推荐
_李小白16 分钟前
【C++学习笔记】新特性之inline变量
c++·笔记·学习
桀人37 分钟前
C++——模板初阶(收录在专栏C++入门到精通)
开发语言·c++
JAVA社区1 小时前
Java进阶全套教程(四)—— SpringMVC框架详解
java·开发语言·spring·面试·职场和发展
Lumbrologist1 小时前
【C++】零基础入门 · 第 2 节:变量、基本数据类型与输入输出
java·开发语言·c++
XX風1 小时前
CMake / Make / Ninja / MSVC / GCC / Clang / MSBuild —— 完整体系化理解
c++
Peter·Pan爱编程2 小时前
10. new_delete 不是 malloc_free 的包装
c++·人工智能·算法
dayuOK63072 小时前
从“爆款复刻”到“个性化创作”:AI辅助写作的技术挑战与演进方向
人工智能·职场和发展·自动化·新媒体运营·媒体
Raink老师3 小时前
【AI面试临阵磨枪-58】AI 生成内容合规、版权、审核机制设计
人工智能·面试·职场和发展
sycmancia3 小时前
Qt——文本打印与光标定位
开发语言·qt
故事和你913 小时前
洛谷-【动态规划1】动态规划的引入2
开发语言·数据结构·c++·算法·动态规划·图论