Skip to content

ScrollMode

Weather scrolling is enabled and visibility of scroll bar options.

Inherits: Enum

Properties

  • ADAPTIVE

    Scrolling is enabled and scroll bar is always shown when running app as web or desktop.

  • ALWAYS

    Scrolling is enabled and scroll bar is always shown.

  • AUTO

    Scrolling is enabled and scroll bar is only shown when scrolling occurs.

  • HIDDEN

    Scrolling is enabled, but scroll bar is always hidden.

Examples#

Showcase#

import flet as ft


def showcase_card(scroll_mode: ft.ScrollMode) -> ft.Container:
    return ft.Container(
        width=280,
        padding=12,
        border=ft.Border.all(1, ft.Colors.RED),
        border_radius=10,
        bgcolor=ft.Colors.SURFACE_CONTAINER_LOW,
        content=ft.Column(
            spacing=8,
            controls=[
                ft.Text(scroll_mode.name, weight=ft.FontWeight.BOLD),
                ft.Text("Scroll inside this panel", size=12),
                ft.Container(
                    height=170,
                    border=ft.Border.all(1, ft.Colors.OUTLINE),
                    border_radius=8,
                    bgcolor=ft.Colors.SURFACE,
                    padding=8,
                    content=ft.Column(
                        spacing=4,
                        scroll=scroll_mode,
                        controls=[ft.Text(f"Item {i + 1}") for i in range(24)],
                    ),
                ),
            ],
        ),
    )


def main(page: ft.Page):
    page.theme_mode = ft.ThemeMode.DARK
    page.horizontal_alignment = ft.CrossAxisAlignment.CENTER

    page.appbar = ft.AppBar(title="ScrollMode Showcase")
    page.add(
        ft.Text("Compare scrollbar visibility and scrolling behavior modes."),
        ft.Row(
            wrap=True,
            spacing=12,
            expand=True,
            scroll=ft.ScrollMode.AUTO,
            alignment=ft.MainAxisAlignment.CENTER,
            controls=[showcase_card(scroll_mode) for scroll_mode in ft.ScrollMode],
        ),
    )


ft.run(main)

Properties#

ADAPTIVE = 'adaptive' class-attribute instance-attribute #

Scrolling is enabled and scroll bar is always shown when running app as web or desktop.

ALWAYS = 'always' class-attribute instance-attribute #

Scrolling is enabled and scroll bar is always shown.

AUTO = 'auto' class-attribute instance-attribute #

Scrolling is enabled and scroll bar is only shown when scrolling occurs.

HIDDEN = 'hidden' class-attribute instance-attribute #

Scrolling is enabled, but scroll bar is always hidden.