|
1 周之前 | |
---|---|---|
.. | ||
README.md | 1 周之前 |
23007ec6
)](https://reflex.dev/docs/getting-started/introduction)
[](https://pepy.tech/projects/reflex)
[](https://discord.gg/T5WSbC2YtQ)
English | 简体中文 | 繁體中文 | Türkçe | हिंदी | Português (Brasil) | Italiano | Español | 한국어 | 日本語 | Deutsch | Persian (پارسی) | Tiếng Việt
Reflex é uma biblioteca para construir aplicações web full-stack em Python puro.
Principais características:
Veja nossa página de arquitetura para aprender como o Reflex funciona internamente.
Abra um terminal e execute (Requer Python 3.10+):
pip install reflex
Instalar reflex
também instala a ferramenta de linha de comando reflex
.
Crie um novo projeto para verificar se a instalação foi bem sucedida. (Mude nome_do_meu_app
com o nome do seu projeto):
mkdir nome_do_meu_app
cd nome_do_meu_app
reflex init
Este comando inicializa um app base no seu novo diretório.
Você pode executar este app em modo desenvolvimento:
reflex run
Você deve conseguir verificar seu app sendo executado em http://localhost:3000.
Agora, você pode modificar o código fonte em nome_do_meu_app/nome_do_meu_app.py
. O Reflex apresenta recarregamento rápido para que você possa ver suas mudanças instantaneamente quando você salva o seu código.
Veja o seguinte exemplo: criar uma interface de criação de imagens por meio do DALL·E. Para fins de simplicidade, vamos apenas chamar a API da OpenAI, mas você pode substituir esta solução por um modelo de ML executado localmente.
Aqui está o código completo para criar este projeto. Isso tudo foi feito apenas em um arquivo Python!
import reflex as rx
import openai
openai_client = openai.OpenAI()
class State(rx.State):
"""Estado da aplicação."""
prompt = ""
image_url = ""
processing = False
complete = False
def get_image(self):
"""Obtenção da imagem a partir do prompt."""
if self.prompt == "":
return rx.window_alert("Prompt Empty")
self.processing, self.complete = True, False
yield
response = openai_client.images.generate(
prompt=self.prompt, n=1, size="1024x1024"
)
self.image_url = response.data[0].url
self.processing, self.complete = False, True
def index():
return rx.center(
rx.vstack(
rx.heading("DALL-E", font_size="1.5em"),
rx.input(
placeholder="Enter a prompt..",
on_blur=State.set_prompt,
width="25em",
),
rx.button(
"Generate Image",
on_click=State.get_image,
width="25em",
loading=State.processing
),
rx.cond(
State.complete,
rx.image(src=State.image_url, width="20em"),
),
align="center",
),
width="100%",
height="100vh",
)
# Adição do estado e da página no app.
app = rx.App()
app.add_page(index, title="Reflex:DALL-E")
Vamos começar com a UI (Interface de Usuário)
def index():
return rx.center(
...
)
Esta função index
define o frontend do app.
Usamos diferentes componentes, como center
, vstack
, input
e button
, para construir o frontend. Componentes podem ser aninhados um no do outro
para criar layouts mais complexos. E você pode usar argumentos de chave-valor para estilizá-los com todo o poder do CSS.
O Reflex vem com 60+ componentes nativos para te ajudar a começar. Estamos adicionando ativamente mais componentes, e é fácil criar seus próprios componentes.
O Reflex representa a sua UI como uma função do seu estado.
class State(rx.State):
"""Estado da aplicação."""
prompt = ""
image_url = ""
processing = False
complete = False
O estado define todas as variáveis (chamadas de vars) em um app que podem mudar e as funções que as alteram.
Aqui, o estado é composto por um prompt
e uma image_url
. Há também os booleanos processing
e complete
para indicar quando desabilitar o botão (durante a geração da imagem) e quando mostrar a imagem resultante.
def get_image(self):
"""Obtenção da imagem a partir do prompt."""
if self.prompt == "":
return rx.window_alert("Prompt Empty")
self.processing, self.complete = True, False
yield
response = openai_client.images.generate(
prompt=self.prompt, n=1, size="1024x1024"
)
self.image_url = response.data[0].url
self.processing, self.complete = False, True
Dentro do estado, são definidas funções chamadas de Handlers de Eventos, que podem mudar as variáveis do estado. Handlers de Eventos são a forma com a qual podemos modificar o estado dentro do Reflex. Eles podem ser chamados como resposta a uma ação do usuário, como o clique de um botão ou a escrita em uma caixa de texto. Estas ações são chamadas de eventos.
Nosso app DALL-E possui um Handler de Evento chamado get_image
, que obtêm a imagem da API da OpenAI. Usar yield
no meio de um Handler de Evento causa a atualização da UI do seu app. Caso contrário, a UI seria atualizada no fim da execução de um Handler de Evento.
Finalmente, definimos nosso app.
app = rx.App()
Adicionamos uma página na raíz do app, apontando para o componente index. Também adicionamos um título que irá aparecer na visualização da página/aba do navegador.
app.add_page(index, title="DALL-E")
Você pode criar um app com múltiplas páginas adicionando mais páginas.
O Reflex foi lançado em Dezembro de 2022 com o nome Pynecone.
A partir de 2025, o Reflex Cloud foi lançado para fornecer a melhor experiência de hospedagem para apps Reflex. Continuaremos a desenvolvê-lo e implementar mais recursos.
O Reflex tem novas versões e recursos chegando toda semana! Certifique-se de marcar com :star: estrela e :eyes: observar este repositório para se manter atualizado.
Nós somos abertos a contribuições de qualquer tamanho! Abaixo, seguem algumas boas formas de começar a contribuir para a comunidade do Reflex.
Estamos ativamente buscando novos contribuidores, não importa o seu nível de habilidade ou experiência. Para contribuir, confira CONTRIBUTING.md.
O Reflex é de código aberto e licenciado sob a Apache License 2.0.