Static Assets
This guide focuses on the areas of working with static assets that are unique to the Vite plugin. For more general documentation, see Static Assets.
The Vite plugin does not require that you provide the assets field in order to enable assets and instead determines whether assets should be included based on whether the client environment has been built. By default, the client environment is built if any of the following conditions are met:
- There is an index.htmlfile in the root of your project
- build.rollupOptions.inputor- environments.client.build.rollupOptions.inputis specified in your Vite config
- You have a non-empty publicdirectory ↗
- Your Worker imports assets as URLs ↗
On running vite build, an output wrangler.json configuration file is generated as part of the build output.
The assets.directory field in this file is automatically populated with the path to your client build output.
It is therefore not necessary to provide the assets.directory field in your input Worker configuration.
The assets configuration should be used, however, if you wish to set routing configuration or enable the assets binding.
The following example configures the not_found_handling for a single-page application so that the fallback will always be the root index.html file.
{  "assets": {    "not_found_handling": "single-page-application"  }}assets = { not_found_handling = "single-page-application" }The Vite plugin ensures that all of Vite's static asset handling ↗ features are supported in your Worker as well as in your frontend.
These include importing assets as URLs, importing as strings and importing from the public directory as well as inlining assets.
Assets imported as URLs ↗ can be fetched via the assets binding.
As the binding's fetch method requires a full URL, we recommend using the request URL as the base.
This is demonstrated in the following example:
import myImage from "./my-image.png";
export default {  fetch(request, env) {    return env.ASSETS.fetch(new URL(myImage, request.url));  },};Assets imported as URLs in your Worker will automatically be moved to the client build output.
When running vite build the paths of any moved assets will be displayed in the console.
Custom headers and redirects are supported at build, preview and deploy time by adding _headers and _redirects files to your public directory ↗.
The paths in these files should reflect the structure of your client build output.
For example, generated assets are typically located in an assets subdirectory ↗.
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Directory
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- © 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark