Analog
Analog ↗ is a fullstack meta-framework for Angular, powered by Vite ↗ and Nitro ↗.
In this guide, you will create a new Analog application and deploy it using Cloudflare Pages.
The easiest way to create a new Analog project and deploy to Cloudflare Pages is to use the create-cloudflare ↗ CLI (also known as C3). To get started, open a terminal and run:
npm create cloudflare@latest my-analog-app -- --framework=analog --platform=pagespnpm create cloudflare@latest my-analog-app --framework=analog --platform=pagesyarn create cloudflare my-analog-app --framework=analog --platform=pagesC3 will walk you through the setup process and create a new project using create-analog, the official Analog creation tool. It will also install the necessary adapters along with the Wrangler CLI.
A binding allows your application to interact with Cloudflare developer products, such as KV, Durable Objects, R2, and D1.
If you intend to use bindings in your project, you must first set up your bindings for local and remote development.
In Analog, server-side code can be added via API Routes ↗. The defineEventHandler() method is used to define your API endpoints in which you can access Cloudflare's context via the provided context field. The context field allows you to access any bindings set for your application.
The following code block shows an example of accessing a KV namespace in Analog.
export default defineEventHandler(async ({ context }) => {  const { MY_KV } = context.cloudflare.env;  const greeting = (await MY_KV.get("greeting")) ?? "hello";
  return {    greeting,  };});Projects created via C3 come installed with a Nitro module that simplifies the process of working with bindings during development:
const devBindingsModule = async (nitro: Nitro) => {  if (nitro.options.dev) {    nitro.options.plugins.push('./src/dev-bindings.ts');  }};
export default defineConfig({  ...  plugins: [analog({    nitro: {      preset: "cloudflare-pages",      modules: [devBindingsModule]    }  })],  ...});This module in turn loads a plugin which adds bindings to the request context in dev:
import { NitroApp } from "nitropack";import { defineNitroPlugin } from "nitropack/dist/runtime/plugin";
export default defineNitroPlugin((nitroApp: NitroApp) => {  nitroApp.hooks.hook("request", async (event) => {    const _pkg = "wrangler"; // Bypass bundling!    const { getPlatformProxy } = (await import(      _pkg    )) as typeof import("wrangler");    const platform = await getPlatformProxy();
    event.context.cf = platform["cf"];    event.context.cloudflare = {      env: platform["env"] as unknown as Env,      context: platform["ctx"],    };  });});In the code above, the getPlatformProxy helper function will automatically detect any bindings defined in your project's Wrangler file and emulate those bindings in local development. You may wish to refer to Wrangler configuration information on bindings.
A new type definition for the Env type (used by context.cloudflare.env) can be generated from the Wrangler configuration file with the following command:
npm run cf-typegenThis should be done any time you add new bindings to your Wrangler configuration.
In order to access bindings in a deployed application, you will need to configure your bindings in the Cloudflare dashboard.
When creating your new project, C3 will give you the option of deploying an initial version of your application via Direct Upload. You can redeploy your application at any time by running following command inside your project directory:
npm run deployIn addition to Direct Upload deployments, you can deploy projects via Git integration. Git integration allows you to connect a GitHub or GitLab repository to your Pages application and have your Pages application automatically built and deployed after each new commit is pushed to it.
Setup requires a basic understanding of Git ↗. If you are new to Git, refer to GitHub's summarized Git handbook ↗ on how to set up Git on your local machine.
Create a new GitHub repository by visiting repo.new ↗. After creating a new repository, go to your newly created project directory to prepare and push your local application to GitHub by running the following commands in your terminal:
# Skip the following three commands if you have built your application# using C3 or already committed your changesgit initgit add .git commit -m "Initial commit"
git branch -M maingit remote add origin https://github.com/<YOUR_GH_USERNAME>/<REPOSITORY_NAME>git push -u origin mainTo deploy your site to Pages:
- Log in to the Cloudflare dashboard ↗ and select your account.
- In Account Home, select Workers & Pages > Create.
- Select the Pages tab.
- Select Connect to Git.
- Select the new GitHub repository that you created and then select Begin setup.
- In the Build settings section, select Analog as your Framework preset. Your selection will provide the following information:
| Configuration option | Value | 
|---|---|
| Production branch | main | 
| Build command | npm run build | 
| Build directory | dist/analog/public | 
Optionally, you can customize the Project name field. It defaults to the GitHub repository's name, but it does not need to match. The Project name value is assigned as your *.pages.dev subdomain.
- After completing configuration, select the Save and Deploy.
Review your first deploy pipeline in progress. Pages installs all dependencies and builds the project as specified. Cloudflare Pages will automatically rebuild your project and deploy it on every new pushed commit.
Additionally, you will have access to preview deployments, which repeat the build-and-deploy process for pull requests. With these, you can preview changes to your project with a real URL before deploying your changes to production.
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