【QML】Loader组件接收内部Item发出的信号,运行相应的槽函数

61 篇文章 2 订阅

1. Loader组件问题

QML Loader组件无法直接以onSignal的方式设置信号处理函数。

2. 代码

Loader{
	id: _mLoader
	anchors.fill: parent
	
	onLoaded: {
		//内部组件发送exitInput信号的时候,运行onExitInput()槽函数
	    _mLoader.item.exitInput.connect(onExitInput);
	
		//内部组件发送enterInput信号的时候,运行onEnterInput()槽函数
	    _mLoader.item.enterInput.connect(onEnterInput);
	}

	function onExitInput(){
		console.log("Exit input")
	}

	function onEnterInput(){
		console.log("Enter input")
	}
	
	Component.onCompleted: {
		//_mCom内部有信号定义:exitInput 和 enterInput
        _mLoader.sourceComponent = _mCom
    }
}

QML中,信号函数是一种用于实现对象间通信的机制,类似于Qt中的信号信号是来自QML对象的通知,而函数则是由信号触发的表达式或函数。在QML中,可以使用signal关键字定义有参或无参的信号。发送信号时,可以使用emit关键字加上信号名和参数进行发送。 为了让信号函数连接起来,需要使用connect函数进行连接。在Qt/C中,连接信号函数需要保持参数顺序和类型一致。而在QML中,连接信号函数更加方便,可以直接在信号之间使用Connections组件进行连接。 例如,在一个QML的Button组件中,可以定义一个信号testSig,然后在按钮点击事件中使用emit关键字发送信号。接着可以使用Connections组件来绑定信号函数,通过onTestSig函数接收信号函数可以在函数体内进行任意的处理,例如打印参数值。 总结来说,QML中的信号函数机制与Qt中类似,可以用于实现对象间的通信和事件处理。通过定义信号、发送信号和连接信号函数,可以实现灵活的交互和逻辑处理。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [【QML事件处理】信号](https://blog.csdn.net/m0_60259116/article/details/129265884)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Qml信号的发送与接收信号函数的使用](https://blog.csdn.net/Shado_walker/article/details/51243408)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [QML学习笔记【05】:QML信号](https://blog.csdn.net/m0_37845735/article/details/128511282)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值