--- title: React Native sidebar_label: React Native description: Build data-intensive mobile apps with React Native. Seamlessly integrate spreadsheets into your app using SheetJS. Securely process and generate Excel files in the field. pagination_prev: demos/static/index pagination_next: demos/desktop/index sidebar_position: 1 sidebar_custom_props: summary: React + Native Rendering --- # Sheets on the Go with React Native import current from '/version.js'; import Tabs from '@theme/Tabs'; import TabItem from '@theme/TabItem'; import CodeBlock from '@theme/CodeBlock'; [React Native](https://reactnative.dev/) is a mobile app framework. It builds iOS and Android apps that use JavaScript for describing layouts and events. [SheetJS](https://sheetjs.com) is a JavaScript library for reading and writing data from spreadsheets. This demo uses React Native and SheetJS to process and generate spreadsheets. We'll explore how to load SheetJS in a React Native app in a few ways: - ["Fetching Remote Data"](#fetching-remote-data) uses the built-in `fetch` to download and parse remote workbook files. - ["Local Files"](#local-files) uses native libraries to read and write files on the device. The "Complete Example" creates an app that looks like the screenshots below:
iOS | Android |
---|---|
data:image/s3,"s3://crabby-images/1f1ad/1f1ad71fc300403a692fcd07814688b436504046" alt="iOS screenshot" | data:image/s3,"s3://crabby-images/a25a2/a25a25745cef580346a636814baf55d19d6e1640" alt="Android screenshot" |
Spreadsheet | Array of Arrays |
---|---|
data:image/s3,"s3://crabby-images/1dc7a/1dc7a075619c02925a95e0a611190befe2e8c43b" alt="`pres.xlsx` data" | ```js [ ["Name", "Index"], ["Bill Clinton", 42], ["GeorgeW Bush", 43], ["Barack Obama", 44], ["Donald Trump", 45], ["Joseph Biden", 46] ] ``` |
Before | After |
---|---|
data:image/s3,"s3://crabby-images/ef348/ef348dec2024e17a9b18de9a600821d28d4d40b9" alt="before screenshot" | data:image/s3,"s3://crabby-images/16cf5/16cf529546ba24f97353b6a8283626ad3fc095b4" alt="after screenshot" |
Before | After |
---|---|
data:image/s3,"s3://crabby-images/70445/70445fa3d21edad1484712db57e73b0bc19cc995" alt="before screenshot" | data:image/s3,"s3://crabby-images/681ac/681ace446d0e1b96490219ed9381c79b3aaa2219" alt="after screenshot" |