edifice.use_effect#
- edifice.use_effect(setup, dependencies=None)[source]#
Side-effect Hook inside a
@component
function.Behaves like React useEffect.
- Parameters:
setup (
Callable
[[],Callable
[[],None
] |None
]) – An effect setup function which returns a cleanup function orNone
.dependencies (
Optional
[Any
]) –The effect setup function will be called when the dependencies are not
__eq__
to the old dependencies.If the dependencies are
None
, then the effect setup function will always be called.
- Return type:
None
- Returns:
None
The setup function will be called after render and after the underlying Qt Widgets are updated.
The setup function may return a cleanup function. If the
dependencies
in the next render are not__eq__
to the dependencies from the last render, then the cleanup function is called and then the new setup function is called.The cleanup function will be called by Edifice exactly once for each call to the setup function. The cleanup function is called after render and before the component is deleted.
If the
dependencies
areNone
, then the new effect setup function will always be called after every render.If you want to call the setup function only once, then pass an empty tuple
()
as thedependencies
.If the setup function raises an Exception then the cleanup function will not be called. Exceptions raised from the setup function and cleanup function will be suppressed.
The setup function can return
None
if there is no cleanup function.The setup function and cleanup function can call the setter of a
use_state()
Hook to update the application state.@component def Effective(self, handler): def setup_handler(): token = attach_event_handler(handler) def cleanup_handler(): remove_event_handler(token) return cleanup_handler use_effect(setup_handler, handler)