component_vue
Decorator to create a component backed by a Vue template.
def component_vue(vue_path: str, vuetify=True) -> Callable[[Callable[P, None]], Callable[P, solara.Element]]:
...
Although many components can be made from the Python side, sometimes it is easier to write components using Vue directly. It can also be beneficial for performance, since instead of creating many widgets from the Python side we only send data to the frontend. If event handling is also done on the frontend, this reduces latency and makes you app feel much smoother.
All arguments of the function are exposed as Vue properties. Argument pairs of the form foo
, and on_foo
are assumed by refer to the same vue property, with on_foo
being the event handler when foo
changes from
the vue template.
Arguments or the form event_foo
should be callbacks that can be called from the vue template. They are
available as the function foo
in the vue template.
See the vue v2 api for more information on how to use Vue, like watch
,
methods
and lifecycle hooks such as mounted
and destroyed
.
See the Vue component example for an example of how to use this decorator.
Examples
A component that takes a foo
argument and an on_foo
callback that gets called when foo
changes (from the frontend).
import solara
@solara.component_vue("my_foo_component.vue")
def MyFooComponent(foo: int, on_foo: Callable[[int], None]):
pass
The following component only takes in a month argument and an event_date_clicked callback that gets called from
the vue template using this.date_clicked({'extra-data': 42, 'day': this.day})
.
import solara
@solara.component_vue("my_date_component.vue")
def MyDateComponent(month: int, event_date_clicked: Callable):
pass
Arguments
vue_path
: The path to the Vue template file.vuetify
: Whether the Vue template uses Vuetify components.