Vue
In this guide, you will create a new Vue ↗ application and deploy to Cloudflare Workers (with the new Beta Workers Assets).
Use the create-cloudflare ↗ CLI (C3) to set up a new project. C3 will create a new project directory, use code from the official Vue template, and provide the option to deploy instantly.
To use create-cloudflare to create a new Vue project with Beta  Workers Assets, run the following command:
npm create cloudflare@latest my-vue-app -- --framework=vue --platform=workerspnpm create cloudflare@latest my-vue-app --framework=vue --platform=workersyarn create cloudflare my-vue-app --framework=vue --platform=workersFor setup, select the following options:
- For What would you like to start with?, choose Framework Starter.
- For Which development framework do you want to use?, choose Vue.
- Complete the framework's own CLI wizard.
- For Do you want to use git for version control?, choose Yes.
- For Do you want to deploy your application?, choose No(we will be making some changes before deploying).
After setting up your project, change your directory by running the following command:
cd my-vue-appAfter you have created your project, run the following command in the project directory to start a local server. This will allow you to preview your project locally during development.
npm run devpnpm run devyarn run devYour project can be deployed to a *.workers.dev subdomain or a Custom Domain, from your own machine or from any CI/CD system, including Cloudflare's own.
The following command will build and deploy your project. If you are using CI, ensure you update your "deploy command" configuration appropriately.
npm run deploypnpm run deployyarn run deployYou can serve static assets in your Vue application by placing them in the ./public/ directory ↗. This can be useful for resource files such as images, stylesheets, fonts, and manifests.
When using Workers Assets, Cloudflare will first attempt to serve any static assets which match the incoming request.
For example, if you have requests for /logo.png and /blog/hello-world.html in your assets directory, and make requests for /logo.png and /blog/hello-world, those files will be served respectively. The html_handling option allows you to customize the serving of HTML files if you have specific needs around redirects and trailing slashes.
If a request does not match a static asset, Cloudflare will then invoke your Worker script module, if one is present. This can be configured with the main property in the Wrangler configuration file.
Finally, if a request does not match any static assets, and either a Worker script module is not present, or from within that Worker script module, the asset binding's fetch method is called (e.g. env.ASSETS.fetch(request)), Cloudflare will fall back to evaluating the not_found_handling behavior. By default, it will serve a null-body 404-status response, but this can be configured to instead serve custom HTML 404 pages, or to serve a single-page application (SPA).
At present, there is no way to customize this routing behavior beyond the html_handling and not_found_handling options. We plan to offer additional configuration controls, such as allowing you to always run the Worker script modules for certain paths, in the future.
Your new project also contains a Worker at ./server/index.ts, which you can use as a backend API for your Vue application. While your Vue application cannot directly access Workers bindings, it can interact with them through this Worker. You can make fetch() requests from your Vue application to the Worker, which can then handle the request and use bindings. Learn how to configure Workers bindings.
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Products
- 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