Unleash: Integrating Feature Flags in React Applications
Introduction
Feature flags are a powerful asset in software development, allowing you to toggle features on or off without deploying new code. This flexibility serves various purposes, including:
- A/B Testing: Run A/B tests on new features to gauge user reactions before a full rollout.
- Incremental Rollouts: Gradually introduce new features to a subset of users before expanding availability.
- Environment-Specific Controls: Manage feature access across different environments like development, staging, and production.
The Unleash SDK for React streamlines the process of incorporating feature flags into your React applications with the following benefits:
- Simple Declarative Syntax: Define feature flags using a straightforward, declarative approach.
- Optimized Rendering: Enhance performance by deferring rendering until feature flags are fetched.
- Class and Functional Component Compatibility: Support for both class-based and functional components.
Installation
1. Setting up a self-hosted Unleash server: The easiest way to run Unleash locally is by using Git and Docker.
1git clone git@github.com:Unleash/unleash.git23cd unleash45docker compose up -d };
2. Accessing the Unleash GUI: Once Docker is up and running, navigate to http://localhost:4242/. You’ll see a login screen.

Use the following credentials to login:
1username: admin2password: unleash4all };
Creating an API access token
Go to the “API Access” tab in the side navigation and click “New API Token.”

Provide a name for the token and choose the SDK type. Since this blog focuses on React, select the Client-side SDK. After choosing the environment, click “Create Token.” Be sure to save the token for future reference.

Unleash React SDK
With your token created, you’re set to integrate Unleash into your React application. Start by installing and configuring the client-side SDK to align with your server’s setup.
Installing package
Use either of the commands (as per your environment) to install the sdk.
1npm install @unleash/proxy-client-react unleash-proxy-client23# or45yarn add @unleash/proxy-client-react unleash-proxy-client };
Configuration
Now import the sdk, configure and wrap your <App/> as following (typically in index.js/ts):
1import { createRoot } from 'react-dom/client';23import { FlagProvider } from '@unleash/proxy-client-react';45const config = {67 url: '<unleash-url>/api/frontend',89 clientKey: '<your-token>',1011 refreshInterval: 15,1213 appName: 'your-app-name',1415};1617const root = createRoot(document.getElementById('root'));1819root.render(2021 <React.StrictMode>2223 <FlagProvider config={config}>2425 <App />2627 </FlagProvider>2829 </React.StrictMode>3031); };
Replace <unleash-url> with Unleash server url, in our case it’s http://localhost:4242 . Replace <your-token> with the token that we created in step 2 of installation. Replace your-app-name with your App’s name (it will be only used to identify your application).
Creating Feature-flag
On the dashboard (in projects tab) click on the default project. You’ll see a window like:

P.s. You might not see the “test” flag as I created it earlier.
Click on the “New feature flag” button. You will see a window like this:

Name your token, let the flag type and project remain the same. Toggle-on “Enable Impression data” and click on “Create feature flag”.
Congratulations! You have created your first feature flag. Now use it in your application.
Consuming feature flag
Head to your component/feature which you want to bind with the feature flag. And bind it as following:
1import { useFlag } from '@unleash/proxy-client-react';23const TestComponent = () => {45 const enabled = useFlag('travel.landing');67 if (enabled) {89 return <SomeComponent />;1011 }1213 return <AnotherComponent />;1415};1617export default TestComponent; };
Now your Test component is bound with the feature flag. You can toggle your flag from the Unleash GUI (click the toggle button under development/production) and see the difference in your frontend:

Conclusion
Integrating feature flags into your React applications with the Unleash SDK provides significant benefits, including enhanced user experience through A/B testing and reduced risk with incremental rollouts. By utilizing feature flags, you can make your development process more adaptable and responsive to user feedback, allowing for real-time feature adjustments without the need for frequent redeployments. Unleash’s powerful integration features make it an essential tool for development teams aiming to implement feature flags smoothly and efficiently.
Why Building the Right MVP Architecture No Longer Slows You Down
Just build a simple monolith for your MVP. You can fix the architecture later...
Read MoreAI-Assisted MVP Development (Vibe Coding)
Building a startup MVP used to be slow, expensive, and stressful especially if you weren’t technical....
Read MoreFrom SEO to AEO & GEO: Why QA Teams Will Own Search Visibility in the AI Era
Search is no longer just a list of links. It’s becoming a decision layer, A place where users expect an immediate, synthesized answer, a recommendation, or a next action...
Read MoreCommon Amazon EventBridge Pitfalls in Production (and How to Avoid Them)
Amazon EventBridge simplifies the implementation of event-driven architectures. Publish an event, configure a rule, attach a target-and the system appears to work seamlessly...
Read MoreBuilding Production-Ready RAG Microservices: A Complete Serverless Architecture Guide
Large Language Models like GPT-4 and Claude have a critical flaw for businesses: they don't know your proprietary data. They can't answer questions about your products...
Read MoreWhat is a Data Lake, Data Warehouse, and Data Lakehouse? - A Simple Beginner’s Guide
Data has become one of the most valuable assets for modern businesses. Every click, transaction, message, and app interaction generates information that companies want to store, analyze, and learn from....
Read MoreImplementing a Scalable AWS Landing Zone: A Practical Guide for DevOps Teams
An AWS Landing Zone is a well-architected, multi-account AWS environment designed to support scalability, security, compliance, and operational excellence from day one....
Read MoreUsing EventBridge for Async Communication in a Serverless Microservice Architecture
Microservices often begin with simple, synchronous communication: Service A calls Service B’s API and waits for a response...
Read MorePros and cons of using DynamoDB
Amazon DynamoDB has become one of the most popular NoSQL databases in the cloud, offering a fully managed, serverless experience....
Read More