React CMS

The easiest way to manage content with React

When it comes to authoring content, pair React with a CMS that’s been built for single-page applications.

Proudly powered by DatoCMS + React:
The International Football Association Board
https://www.theifab.com/
Flightcontrol
https://www.flightcontrol.dev/
Buildkite
https://buildkite.com/
Italian Tech Week
https://italiantechweek.com/en
Choose Better - B Lab Europe
https://choosebetter.bcorporation.eu/
Category API
https://categoryapi.com
Alma
https://almapay.com
Storyworlds Builders (SWOB)
https://www.storyworldsbuilders.com/
Clickatell
https://www.clickatell.com/
Shopmonkey
https://www.shopmonkey.io/
UpKeep
https://www.upkeep.com/
Martin Smerdel
https://martinsmerdel.com
Khemistry
https://khemistry.com.au/
The Sistergood
https://www.thesistergood.com/
L’Officiel
https://www.lofficiel.com/
Polimoda
https://www.polimoda.com/
Arduino
https://www.arduino.cc/education
Real Estate Jobs
https://realestatejobs.io
Great Southern
https://greatsouthernfarms.com.au/
Luganodante
https://luganodante.com
Portal Monitor
https://portalmonitor.io
PayFit
https://payfit.com/en
iKeys
https://ikeys-realty.com/en
Al finans
https://alfinans.dk/
Versa
https://versa.agency
Bunker One
https://bunkerone.com/
Deutsche Telekom Inflight
https://inflight.telekom.net/

Worldwide CDN

React is fast, and so your CMS should be

If your content is always fetched from a single geographical location, there’s no point in building a website with a serverless architecture. Dato CMS offers your content from a CDN with edges all around the globe, minimizing your React app latency.

Read more about our Worldwide CDN

ADL
Adelaide, Australia
Distance
AMS
Amsterdam, Europe
Distance
DCA
Ashburn (Metro), North America
Distance
IAD
Ashburn (Metro), North America
Distance
PDK
Atlanta (Metro), North America
Distance
AKL
Auckland, Australia
Distance
BKK
Bangkok, Asia
Distance
BOG
Bogota, South America
Distance
BOS
Boston, North America
Distance
BNE
Brisbane, Australia
Distance
BRU
Brussels, Europe
Distance
EZE
Buenos Aires, South America
Distance
YYC
Calgary, North America
Distance
CPT
Cape Town, Africa
Distance
MAA
Chennai, India
Distance
CHI
Chicago (Metro), North America
Distance
CHC
Christchurch, Australia
Distance
CMH
Columbus, North America
Distance
LCK
Columbus, North America
Distance
CPH
Copenhagen, Europe
Distance
CWB
Curitiba, South America
Distance
ADS
Dallas (Metro), North America
Distance
DFW
Dallas (Metro), North America
Distance
DEL
Delhi, India
Distance
DEN
Denver, North America
Distance
DTW
Detroit, North America
Distance
DXB
Dubai, Asia
Distance
DUB
Dublin, Europe
Distance
FOR
Fortaleza, South America
Distance
FRA
Frankfurt (Metro), Europe
Distance
WIE
Frankfurt, Europe
Distance
FJR
Fujairah Al Mahta, Asia
Distance
GNV
Gainesville, North America
Distance
ACC
Ghana, Africa
Distance
HEL
Helsinki, Europe
Distance
HKG
Hong Kong, Asia
Distance
HNL
Honolulu, North America
Distance
IAH
Houston, North America
Distance
HYD
Hyderabad, India
Distance
JNB
Johannesburg, Africa
Distance
MCI
Kansas City, North America
Distance
CCU
Kolkata, India
Distance
KUL
Kuala Lumpur, Asia
Distance
LIM
Lima, South America
Distance
LIS
Lisbon, Europe
Distance
LCY
London, Europe
Distance
LHR
London, Europe
Distance
LON
London, Europe
Distance
BUR
Los Angeles (Metro), North America
Distance
HHR
Los Angeles (Metro), North America
Distance
LAX
Los Angeles (Metro), North America
Distance
MAD
Madrid, Europe
Distance
MAN
Manchester, Europe
Distance
MNL
Manila, Asia
Distance
MRS
Marseille, Europe
Distance
MEL
Melbourne, Australia
Distance
MIA
Miami, North America
Distance
LIN
Milan, Europe
Distance
MXP
Milan, Europe
Distance
MSP
Minneapolis, North America
Distance
STP
Minneapolis, North America
Distance
YUL
Montreal, North America
Distance
BOM
Mumbai, India
Distance
MUC
Munich, Europe
Distance
LGA
New York City, North America
Distance
NYC
New York City (Metro), North America
Distance
EWR
Newark, North America
Distance
ITM
Osaka, Asia
Distance
OSL
Oslo, Europe
Distance
PMO
Palermo, Europe
Distance
PAO
Palo Alto (Metro), North America
Distance
CDG
Paris (Metro), Europe
Distance
PAR
Paris (Metro), Europe
Distance
PER
Perth, Australia
Distance
PHX
Phoenix, North America
Distance
PDX
Portland, North America
Distance
GIG
Rio de Janeiro, South America
Distance
FCO
Rome, Europe
Distance
SJC
San Jose, North America
Distance
WVI
San Jose, North America
Distance
SCL
Santiago, South America
Distance
GRU
Sao Paulo (Metro), South America
Distance
BFI
Seattle (Metro), North America
Distance
ICN
Seoul, South Korea
Distance
QPG
Singapore, Asia
Distance
SIN
Singapore, Asia
Distance
SOF
Sofia, Europe
Distance
STL
St.Louis, North America
Distance
BMA
Stockholm, Europe
Distance
SYD
Sydney, Australia
Distance
WSI
Sydney, Australia
Distance
TYO
Tokyo, Asia
Distance
NRT
Tokyo (Metro), Asia
Distance
YYZ
Toronto, North America
Distance
YVR
Vancouver, North America
Distance
VIE
Vienna, Europe
Distance
WLG
Wellington, Australia
Distance

GraphQL Content API

Ask for what you need, get exactly that

Our Content Delivery API is built with GraphQL. That means powerful developer tools, multiple resources in a single request and complete control over the data your website downloads. The perfect solution for a React CMS.

Read more about our GraphQL API
{}

“We are quite happy because finally we have a real CMS 😅”

Johan Frick
CTO at Coolstuff

React images

State of the art for responsive and progressive images

Serving optimized images is incredibly hard, but our CMS is optimized for React. Using our GraphQL Content API and our React component, you can implement lazy loaded, responsive images in one line of code. Avoid any layout jumping, offer instant previews of images while they load. It’s like magic.

Read more about our React components!
Before
React with DatoCMS

React CMS example

DatoCMS Preview API = content editors happiness

If you're using React as a single-page application (SPA), you can easily switch GraphQL endpoint to fetch real-time previews of the changes you make to any content stored in DatoCMS (text, images, videos). Give it a try, it's magic!

src/App.js
import { GraphQLClient, ClientContext } from 'graphql-hooks'
const endpoint = process.env.PREVIEW_MODE ?
'https://graphql.datocms.com/preview' :
'https://graphql.datocms.com/';
const client = new GraphQLClient({ url: endpoint });
function App() {
return (
<ClientContext.Provider value={client}>
<Movie />
</ClientContext.Provider>
);
}
// src/Movie.js
import React from "react";
import { useQuery } from "graphql-hooks";
const Movie = () => {
const { loading, error, data } = useQuery(
query: `{
movie(filter: { title: { eq: "Inception" } }) {
title
releaseDate
actors {
name
}
}
}`
);
if (loading) return <div>Loading...</div>;
if (error) return <div>Something bad happened</div>;
return (
<div>
<h1>{data.movie.title}</h1>
{/* ... */}
</div>
);
};
Acme Inc. - DatoCMS
Create new Blog post
Title
The Best Video Games to Play
Author
Dan Poe
Content
Text
Lorem ipsum....
Gallery
Text
Lorem ipsum....
CTA label
Try it now!
CTA URL
http://...
Quote
Lorem ipsum....
Author
Steve Jobs
Add a new block:
Text
Gallery
Quote
Call to action
Save Blog Post

A component-centric CMS, just like React

Reacts makes using components easy right from the get-go, and you should expect the same from your CMS. A component-based approach allows developers to clearly divide work amongst themselves and progress without having to rely on each other every step of the way.

Read more about DatoCMS modular blocks

Start using DatoCMS today
According to Gartner 89% of companies plan to compete primarily on the basis of customer experience this year. Don't get caught unprepared.
  • No credit card
  • Easy setup
Subscribe to our newsletter! 📥
One update per month. All the latest news and sneak peeks directly in your inbox.
support@datocms.com ©2024 Dato srl, all rights reserved P.IVA 06969620480