Skip to main content

Serves Vue assets on a FastAPI app. Use fastapi-vue-setup tool to add Vue build to your package.

Project description

fastapi-vue

Implements Single-Page-App serving at site root with FastAPI, that the standard StaticFiles module cannot handle. This also caches and zstd compresses the files for lightning-fast operation. This is primarily meant for use with Vue frontend, but technically can host any static files in a similar manner.

Installation

Script fastapi-vue-setup should normally be used to convert or create a project with connection between FastAPI and Vue. The target project will depend on this package to serve its static files.

uvx fastapi-vue-setup --help

Refer to instructions below for further configuration.

Usage

from contextlib import asynccontextmanager
from fastapi import FastAPI
from fastapi_vue import Frontend

frontend = Frontend(
    Path(__file__).with_name("frontend-build"),
    spa=True,
    cached=["/assets/"],
)

@asynccontextmanager
async def lifespan(app: FastAPI):
    await frontend.load()
    yield

app = FastAPI(lifespan=lifespan)

# Add API routes here...

# Final catch-all route for frontend files (keep at end of file)
frontend.route(app, "/")

Configuration

  • directory: Path to static files directory
  • spa: Enable SPA mode (serve index.html for unknown routes)
  • cached: Path prefixes for immutable cache headers (browser won't check for changes)
  • favicon: Path to serve at /favicon.ico (e.g., "/logo.png" will be served as image/png)
  • zstdlevel: Compression level (default: 18)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fastapi_vue-0.5.0.tar.gz (5.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fastapi_vue-0.5.0-py3-none-any.whl (6.6 kB view details)

Uploaded Python 3

File details

Details for the file fastapi_vue-0.5.0.tar.gz.

File metadata

  • Download URL: fastapi_vue-0.5.0.tar.gz
  • Upload date:
  • Size: 5.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.21 {"installer":{"name":"uv","version":"0.9.21","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for fastapi_vue-0.5.0.tar.gz
Algorithm Hash digest
SHA256 a59ceb8ff7050441b6fc0988344353d26ccfca3b8d189dc549782f0d3737d8c0
MD5 08f2b7464a7f1a33c2fbf1dc307a1868
BLAKE2b-256 35b3c32f4f4aff7536f2c1567e740a1c6ae7021202e12e4aaa4821865126211f

See more details on using hashes here.

File details

Details for the file fastapi_vue-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: fastapi_vue-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 6.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.21 {"installer":{"name":"uv","version":"0.9.21","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for fastapi_vue-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 47315b720aaa39bfcef00d7bcea98e2f96646ece5bfeaa6e67473349bdf54ff2
MD5 379641666d1c456cbca60fb6d0e78325
BLAKE2b-256 9ae4e3664320050b37c5eabf1facfa49a73f5714ed19fa93a54b5bb67ec35523

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page