# Flet **Repository Path**: mirrors/Flet ## Basic Information - **Project Name**: Flet - **Description**: Flet 是一个 Python 框架,使您能够以自己喜欢的语言轻松构建实时 Web、移动和桌面应用程序,并安全地与您的团队共享 - **Primary Language**: Python - **License**: Apache-2.0 - **Default Branch**: main - **Homepage**: https://www.oschina.net/p/flet - **GVP Project**: No ## Statistics - **Stars**: 10 - **Forks**: 0 - **Created**: 2023-03-19 - **Last Updated**: 2025-10-04 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README

Flet logo

Build multi-platform apps in Python powered by Flutter

License Package version Supported Python versions Supported Python versions Build status

--- Flet is a framework that allows building web, desktop and mobile applications in Python without prior experience in frontend development. ### ⚡️ From idea to app in minutes An internal tool or a dashboard for your team, weekend project, data entry form, kiosk app, or high-fidelity prototype - Flet is an ideal framework to quickly hack great-looking interactive apps to serve a group of users. ### 📐 Simple architecture No more complex architecture with JavaScript frontend, REST API backend, database, cache, etc. With Flet you just write a monolith stateful app in Python only and get multi-user, real-time Single-Page Application (SPA). ### 🔋 Batteries included To start developing with Flet, you just need your favorite IDE or text editor. No SDKs, no thousands of dependencies, no complex tooling - Flet has a built-in web server with assets hosting and desktop clients. ### Powered by Flutter Flet UI is built with [Flutter](https://flutter.dev/), so your app looks professional and could be delivered to any platform. Flet simplifies the Flutter model by combining smaller "widgets" to ready-to-use "controls" with an imperative programming model. ### 📱 Deliver to any device or platform Package your Flet app as a standalone desktop app (for Windows, macOS, and Linux), mobile app (for iOS and Android), dynamic/static Web app or as a Progressive Web App ([PWA](https://web.dev/what-are-pwas/)). ## Flet app example Below is a simple "Counter" app, with a text field and two buttons to increment and decrement the counter value: ```python title="counter.py" import flet as ft def main(page: ft.Page): page.title = "Flet counter example" page.vertical_alignment = ft.MainAxisAlignment.CENTER input = ft.TextField(value="0", text_align=ft.TextAlign.RIGHT, width=100) def minus_click(e): input.value = str(int(input.value) - 1) page.update() def plus_click(e): input.value = str(int(input.value) + 1) page.update() page.add( ft.Row( alignment=ft.alignment.center, controls=[ ft.IconButton(ft.Icons.REMOVE, on_click=minus_click), input, ft.IconButton(ft.Icons.ADD, on_click=plus_click), ], ) ) ft.run(main) ``` To run the app, install `flet`: ```bash pip install 'flet[all]' ``` then launch the app: ```bash flet run counter.py ``` This will open the app in a native OS window - what a nice alternative to Electron! 🙂

To run the same app as a web app, update the last line in your script to: ```python ft.run(main, view=flet.AppView.WEB_BROWSER) ``` Alternatively, you can use the `--web` flag when running the `flet run` command: ```bash flet run --web counter.py ```

## Learn more * [Website](https://flet.dev) * [Documentation](https://docs.flet.dev) * [Roadmap](https://flet.dev/roadmap) * [Apps Gallery](https://docs.flet.dev/gallery) ## Community * [Discussions](https://github.com/flet-dev/flet/discussions) * [Discord](https://discord.gg/dzWXP8SHG8) * [X (Twitter)](https://twitter.com/fletdev) * [Bluesky](https://bsky.app/profile/fletdev.bsky.social) * [Email us](mailto:hello@flet.dev) ## Contributing Want to help improve Flet? Check out the [contribution guide](https://docs.flet.dev/contributing).