Skip to content

Routes

marimo.routes

routes(
    routes: dict[
        str,
        Union[
            Callable[[], object],
            Callable[[], Coroutine[None, None, object]],
            object,
        ],
    ]
)

Bases: UIElement[str, str]

Renders a list of routes that are switched based on the URL path.

Routes currently don't support nested routes, or dynamic routes (e.g. #/user/:id). If you'd like to see these features, please let us know on GitHub: https://github.com/marimo-team/marimo/issues

For a simple-page-application (SPA) experience, you should use hash-based routing. For example, prefix your routes with #/.

If you are using a multi-page-application (MPA) with marimo.create_asgi_app, you should use path-based routing. For example, prefix your routes with /.

Examples:

mo.routes(
    {
        "#/": render_home,
        "#/about": render_about,
        "#/contact": render_contact,
        mo.routes.CATCH_ALL: render_home,
    }
)
PARAMETER DESCRIPTION
routes

A dictionary of routes, where the key is the URL path and the value is a function that returns the content to display.

TYPE: dict[str, Union[Callable[[], object], Callable[[], Coroutine[None, None, object]], object]]

RETURNS DESCRIPTION
Html

An Html object.

CATCH_ALL class-attribute instance-attribute

CATCH_ALL = '{/*path}'

DEFAULT class-attribute instance-attribute

DEFAULT = '/'

text property

text: str

A string of HTML representing this element.

value property writable

value: T

The element's current value.

batch

batch(*args: Any, **kwargs: Any) -> Any

callout

callout(*args: Any, **kwargs: Any) -> Html

center

center(*args: Any, **kwargs: Any) -> Html

form

form(
    label: str = "",
    *,
    bordered: bool = True,
    loading: bool = False,
    submit_button_label: str = "Submit",
    submit_button_tooltip: Optional[str] = None,
    submit_button_disabled: bool = False,
    clear_on_submit: bool = False,
    show_clear_button: bool = False,
    clear_button_label: str = "Clear",
    clear_button_tooltip: Optional[str] = None,
    validate: Optional[
        Callable[[Optional[JSONType]], Optional[str]]
    ] = None,
    on_change: Optional[
        Callable[[Optional[T]], None]
    ] = None
) -> form[S, T]

Create a submittable form out of this UIElement.

Use this method to create a form that gates the submission of a UIElements value until a submit button is clicked.

The value of the form is the value of the underlying element the last time the form was submitted.

Examples.

Convert any UIElement into a form:

prompt = mo.ui.text_area().form()

Combine with HTML.batch to create a form made out of multiple UIElements:

form = (
    mo.ui.md(
        '''
    **Enter your prompt.**

    {prompt}

    **Choose a random seed.**

    {seed}
    '''
    )
    .batch(
        prompt=mo.ui.text_area(),
        seed=mo.ui.number(),
    )
    .form()
)

Args.

  • label: A text label for the form.
  • bordered: whether the form should have a border
  • loading: whether the form should be in a loading state
  • submit_button_label: the label of the submit button
  • submit_button_tooltip: the tooltip of the submit button
  • submit_button_disabled: whether the submit button should be disabled
  • clear_on_submit: whether the form should clear its contents after submitting
  • show_clear_button: whether the form should show a clear button
  • clear_button_label: the label of the clear button
  • clear_button_tooltip: the tooltip of the clear button
  • validate: a function that takes the form's value and returns an error message if the value is invalid, or None if the value is valid

left

left(*args: Any, **kwargs: Any) -> Html

right

right(*args: Any, **kwargs: Any) -> Html

send_message

send_message(
    message: Dict[str, object],
    buffers: Optional[Sequence[bytes]],
) -> None

Send a message to the element rendered on the frontend from the backend.

style

style(*args: Any, **kwargs: Any) -> Html

python import marimo

app = marimo.App()

@app.cell def __(): import marimo as mo return

@app.cell def __(): mo.sidebar( [ mo.md("# marimo"), mo.nav_menu( { "#/": f"{mo.icon('lucide:home')} Home", "#/about": f"{mo.icon('lucide:user')} About", "#/contact": f"{mo.icon('lucide:phone')} Contact", "Links": { "https://twitter.com/marimo_io": "Twitter", "https://github.com/marimo-team/marimo": "GitHub", }, }, orientation="vertical", ), ] ) return

@app.cell def __(): mo.routes({ "#/": mo.md("# Home"), "#/about": mo.md("# About"), "#/contact": mo.md("# Contact"), mo.routes.CATCH_ALL: mo.md("# Home"), }) return