- Getting started
- Feature flags and AI Configs
- Releases
- Observability
- Product analytics
- Experimentation
- Metrics
- Warehouse native
- Infrastructure
- Your account
Creating new flags
Overview
This topic explains how to create new feature flags in LaunchDarkly. You can use feature flags in any aspect of your application, from the customer-facing user interface (UI) to the backend.
The procedures in this topic assume that you have already configured a LaunchDarkly SDK and are ready to use the LaunchDarkly UI.
You must indicate if you are using either mobile or client-side SDKs
By default, flags are only available to server-side SDKs. If you don’t check theSDKs using Mobile Key and/orSDKs using client-side ID boxes when creating a flag, then your mobile and client-side SDKs will not be able to evaluate the flag. To learn more, readMake flags available to client-side and mobile SDKs.
In the LaunchDarkly UI, you can create a new flag, clone and modify an existing flag to create new ones, and set default values for flags.
Create a feature flag
You can create and modify feature flags from theFlags list. To learn more, readThe Flags list.
To create a feature flag:
- ClickCreate and chooseFlag. The “Create flag” dialog appears.
- Enter a unique, human-readableName. A suggested key auto-populates from the name you enter, but you can customize it if you wish.
- (Optional) ClickEdit key to update the flag key. You’ll use this key to reference the flag in your code.
Flag keys are important and permanent
After you save the flag key, you cannot modify it. You can change a flag’s name, however, whenever you want.
If your organization requires a specific convention for flag keys, you can configure that in the project settings. To learn more, readFlag key conventions.
Whether your organization uses a specific convention or not, be sure to designate flag keys with naming conventions that the SDKs you use support. For example, if your SDK does not use dot notation, you may not want to use dot notation in your flag keys. If you do, LaunchDarkly automatically converts the key to a format your SDK can use, but this can cause collisions if two flags have similar keys. There are configuration options at the SDK level that help you avoid these issues. To learn more, readFlag keys in the React Web SDK.
- (Optional) Enter aDescription of the flag. A brief, human-readable description helps your account members understand what the flag is for. Flag descriptions can include Markdown and inline Confluence links. To learn more about LaunchDarkly’s integration with Confluence, readConfluence embedded pages.
- (Optional) ClickNo template and select aflag template:- Custom: A flag that you can configure exactly how you wish.
- Release: A temporary boolean flag designed for feature releases. By default, it servesfalseto all targets. Although it supports release use cases, it does not configure any rollout or targeting behavior automatically. You can add that behavior after the flag is created.
- Kill switch: A permanent flag that enables or disables non-core functionality.
- Experiment: A flag that you can use to test a hypothesis and improve on your findings.
- 2-,4-, or6-stage migration: A temporary flag used to migrate data or systems while keeping your application available.
 
- (Optional) Click on your member name to change theflag maintainer.
- (Optional) Click on the tag icon to add one or moretags.
Tags let you sort flags into groups
Tags are useful for managing flag permissions using custom roles. For example, you can use a specific tag to determine who has read or write access for the flag. To learn more, readRoles.
- ClickCreate flag.
The flagTargeting tab appears.
After you create a flag, you can make further changes to it as needed, such as:
- updating flag variations
- updating flag targeting
- adding the flag to a view
- adding the flag to a release pipeline
- marking the flag as temporary
- marking the flag as unavailable to client-side SDKs
You can also use the REST API:Create a feature flag
Feature flag limits
By default, LaunchDarkly allows you to create 5,000 feature flags per project. You can create more upon request. To learn more, readHow to right size when you are over LaunchDarkly system resource count limits.
Make flags available to client-side and mobile SDKs
By default, flags are only available to server-side SDKs. If you’re using a client-side or mobile SDK, you must make your flags available to client-side or mobile SDKs for those SDKs to be able to evaluate them. If a client-side or mobile SDK tries to evaluate a feature flag that is not available to it, then LaunchDarkly serves the fallback value for that flag.
When you create a new flag, you can choose to make the flag available to SDKs that use client-side IDs, SDKs that use mobile keys, or both.
For existing flags, you can choose which SDKs flags are available to on the flag’s “Settings” page:

If you’re using client-side or mobile SDKs, and your flags haveprerequisites, then the prerequisite flags must also be available to client-side or mobile SDKs.
You can update your project settings so that all new flags are automatically available to client-side or mobile SDKs. To learn how, readClient-side availability. LaunchDarkly accounts created after October 21, 2025 have this box checked by default.
Security implications of making flags available to mobile SDKs
SDKs for mobile devices use mobile SDK keys, which are readily available to mobile apps. A leaked mobile SDK key allows the holder to circumvent JavaScript’s Secure Mode. This can give the holder access to the value of every flag for any context, even without knowing the SDK key that hashes the context key in Secure Mode.
To learn more, readChoosing an SDK type.
Configure the same flag in different environments
All environments within a project have the same set of feature flags. When you create a new feature flag, it is created in every environment in your LaunchDarkly project. That flag isscoped to your entire project.
Understanding flag scopes
Flag scoping refers to the parts of LaunchDarkly where a flag is available or used. If a flag is scoped at the project level, it is available to all environments within the project, because projects contain environments. To learn more about projects, readProjects.
To learn more about environments, readEnvironments.
Flag configuration settings are specific to each environment. The changes you make in one environment do not apply to the same flag in any other environment. If you want to, you can configure the same flag in a unique way for every environment you have.
To configure a flag in a different environment:
- Navigate to theFlags list. 
- Click the name of the flag you want to modify. 
- Click on the environment you want to edit the flag in. - If the environment is not displayed, click the+ to display the list of environments, and select the environment you want:
  - The environment selection menu. 
- Make any edits as needed. 
- ClickReview and save. 
Set default values
When you create a feature flag, some of its variations are designated as default values. You can accept the defaults or change them. When you change default values for a new flag, LaunchDarkly creates the flag across all environments in your project with the new variations set as its default on and off values.

To learn more about default flag values, readChange default flag values.
You can enforce project-level default flag settings
You can optionally configure default flag settings for a project, which LaunchDarkly will apply to any new flags you create within that project. To learn how, readFlag templates.