A tiny React component to fetch HTTP requests. It requires React >= 16.3.0
$ # With npm
$ npm install --save react-fetchino
$ # Or yarn
$ yarn add react-fetchino
Name | Type | Required | Description |
---|---|---|---|
url | string | true | URL of the resource to fetch |
options | object | false | Overrides the default options {} |
render | function | false | Can be used instead of children |
import React, { Component, Fragment } from 'react';
import Fetchino from 'react-fetchino';
// Pattern: Function as Child Component
// Props: required
class App extends Component {
render() {
const url = 'https://swapi.co/api/planets/1/';
return (
<Fetchino url={url}>
{({ loading, error, data }) => (
<Fragment>
{ loading && <LoadingComponent /> }
{ error && <ErrorComponent message={error} /> }
{ data && <PlanetComponent data={data} /> }
</Fragment>
)}
</Fetchino>
);
}
}
// Pattern: Render Props
// Props: all
class App extends Component {
render() {
const url = 'https://jsonplaceholder.typicode.com/posts';
const options = {
method: 'POST',
headers: {
'Content-type': 'application/json'
},
body: {
test: 'Test',
}
};
return (
<Fetchino
url={url}
options={options}
render={({ loading, error, data }) => (
<Fragment>
{loading && <LoadingComponent />}
{error && <ErrorComponent message={error} />}
{data && <PostComponent data={data} />}
</Fragment>
)}
/>
);
}
}
Note: if both render and children are functions, render will be ignored.
Click here to open the live demo.
$ npm run test:watch
$ npm run build
$ npm run test
$ npm run test:coverage
- Server-side rendering
- Support for “createFetcher” (see simple-cache-provider)