Installation
- NPM
- Yarn
yarn add @data-client/react @data-client/test @data-client/hooks @data-client/rest
npm install --save @data-client/react @data-client/test @data-client/hooks @data-client/rest
TypeScript is optional, but requires at least version 3.7 and strictNullChecks for full type enforcement.
Add provider at top-level component
- React Web 16+
- React Web 18+
- React Native
- NextJS
index.tsx
import { CacheProvider } from '@data-client/react';
import ReactDOM from 'react-dom';
ReactDOM.render(
<CacheProvider>
<App />
</CacheProvider>,
document.body,
);
index.tsx
import { CacheProvider } from '@data-client/react';
import ReactDOM from 'react-dom';
ReactDOM.createRoot(document.body).render(
<CacheProvider>
<App />
</CacheProvider>,
);
index.tsx
import { CacheProvider } from '@data-client/react';
import { AppRegistry } from 'react-native';
const Root = () => (
<CacheProvider>
<App />
</CacheProvider>
);
AppRegistry.registerComponent('MyApp', () => Root);
npm install --save @data-client/ssr @data-client/redux redux
pages/_document.tsx
import { DataClientDocument } from '@data-client/ssr/nextjs';
export default DataClientDocument;
pages/_app.tsx
import { AppCacheProvider } from '@data-client/ssr/nextjs';
import type { AppProps } from 'next/app';
export default function App({ Component, pageProps }: AppProps) {
return (
<AppCacheProvider>
<Component {...pageProps} />
</AppCacheProvider>
);
}
Alternatively integrate state with redux
Older browser support
If your application targets older browsers (a few years or more), be sure to load polyfills. Typically this is done with @babel/preset-env useBuiltIns: 'entry', coupled with importing core-js at the entrypoint of your application.
This ensures only the needed polyfills for your browser support targets are included in your application bundle.
For instance TypeError: Object.hasOwn is not a function
Internet Explorer support
If you see Uncaught TypeError: Class constructor Resource cannot be invoked without 'new'
,
follow the instructions to add legacy browser support to packages
Example
Explore more Reactive Data Client demos