Changelog
New updates and improvements at Cloudflare. Subscribe to RSS
Import `env` to access bindings in your Worker's global scope
You can now access bindings
from anywhere in your Worker by importing the env
object from cloudflare:workers
.
Previously, env
could only be accessed during a request. This meant that
bindings could not be used in the top-level context of a Worker.
Now, you can import env
and access bindings such as secrets
or environment variables in the
initial setup for your Worker:
import { env } from "cloudflare:workers";import ApiClient from "example-api-client";
// API_KEY and LOG_LEVEL now usable in top-level scopeconst apiClient = ApiClient.new({ apiKey: env.API_KEY });const LOG_LEVEL = env.LOG_LEVEL || "info";
export default { fetch(req) { // you can use apiClient or LOG_LEVEL, configured before any request is handled },};
Additionally, env
was normally accessed as a argument to a Worker's entrypoint handler,
such as fetch
.
This meant that if you needed to access a binding from a deeply nested function,
you had to pass env
as an argument through many functions to get it to the
right spot. This could be cumbersome in complex codebases.
Now, you can access the bindings from anywhere in your codebase
without passing env
as an argument:
// helpers.jsimport { env } from "cloudflare:workers";
// env is *not* an argument to this functionexport async function getValue(key) { let prefix = env.KV_PREFIX; return await env.KV.get(`${prefix}-${key}`);}
For more information, see documentation on accessing env
.
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