Connecting Objects to Signals

To receive a notification when a particular signal is emitted for a particular object, the object definition should declare a signal handler named on<Signal> where <Signal> is the name of the signal, with the first letter capitalized. The signal handler should contain the JavaScript code to be executed when the signal handler is invoked.

QML types have predefined signals that are emitted when users interact with the application. For example, the MouseArea type from the QtQuick module has a clicked signal that is emitted whenever the mouse is clicked within the area. Since the signal name is clicked, the signal handler for receiving this signal is named onClicked.

For more information about signals and signal handlers, see Signal and Handler Event System.

To access a signal outside of the object that emits it, you can use the Connections type for connecting to signals of arbitrary objects. A connections object can receive any signal from its specified target. You can connect objects to signals that are available to them in the Connections view.

To connect objects to signals:

  1. In the Connections view, select the Connections tab.
  2. Select the (Add) button to add a connection.
  3. Double-click the value in the Target column to add the object to connect to a signal.
  4. Double-click the value in the Signal Handler column to select the signal that the connection will listen to from a list of all signals available for the object.
  5. Double-click the value in the Actions column to specify the action to perform when the signal is emitted. You use JavaScript to specify the actions.

© 2019 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.