Polyfills and patches missing or partially supported web and core APIs.
There are several APIs which React Native does not support. When available, they usally are not spec-conformant. This package aims to fill that gap by providing polyfills and patches to said APIs.
As of React Native v0.63.3:
URLandURLSearchParamsare partially implemented.FormDatais partially implementedFileReader.readAsArrayBufferis not implementedReadableStreamis not supported and, by extension,Response.bodyis not implemented. Related discussions:btoaandatobare not supportedTextEncoderandTextDecoderare not supported- ...and others
$ npm install react-native-polyfill-globals- react-native-url-polyfill
- web-streams-polyfill
- base-64
- text-encoding
- react-native-fetch-api
- react-native-get-random-values
Install the above as necessary.
- Implemented by react-native+0.63.3.patch
FormData.set- Handling of
Blobs byFormData FileReader.readAsArrayBuffer
URLandURLSearchParamsprovided by react-native-url-polyfillReadableStreamprovided by web-streams-polyfillbtoaandatobprovided by base-64TextEncoderandTextDecoderprovided by text-encodingfetchfor text streaming provided by react-native-fetch-apicrypto.getRandomValuesprovided by react-native-get-random-values
Import the polyfill function and call it whenever.
import { polyfill } from 'react-native-polyfill-globals';
polyfill();Add the following import to the top of your app's entry file, index.js, located at the root of your project.
import 'react-native-polyfill-globals/auto';import { polyfill as polyfillBase64 } from 'react-native-polyfill-globals/src/base64';
import { polyfill as polyfillEncoding } from 'react-native-polyfill-globals/src/encoding';
import { polyfill as polyfillReadableStream } from 'react-native-polyfill-globals/src/readable-stream';
import { polyfill as polyfillURL } from 'react-native-polyfill-globals/src/url';
import { polyfill as polyfillFetch } from 'react-native-polyfill-globals/src/fetch';
import { polyfill as polyfillCrypto } from 'react-native-polyfill-globals/src/crypto';Patch files located at the patches directory provide additional polyfills and fixes.
Apply all at once with patch-package:
$ npm install -D patch-package
$ npx patch-package --patch-dir node_modules/react-native-polyfill-globals/patchesApply invidually with Git:
$ git apply --ignore-whitespace node_modules/react-native-polyfill-globals/react-native+0.63.3.patchApply invidually with patch:
$ patch -p1 -i node_modules/react-native-polyfill-globals/react-native+0.63.3.patchNote that Metro, React Native's bundler, at this time does not support tree-shaking nor dead code elimination. As such, beware that even if you apply polyfills selectively and don't use them at runtime, the code will be included in the production bundle regardless. If you don't need a given polyfill, do not import it at all.
- node-libs-react-native - Node.js core modules for React Native.
- rn-nodeify - Hack to allow React Native projects to use Node core modules and npm modules that use them.
- ReactNativify - A saner approach on how to use Node.js libraries in React Native.
MIT © André Costa Lima