fs.writeFile is not working on my ReactJs / NodeJs app

I am trying to write some stuff in a file using reactJS and nodeJs but it doesnt work. Here is my code, is a simple one and i get that fs.writeFile is not a function. I get this error for each function that i use from fs. In node_module i have the folder for fs but inside i only have package.json and a readme. I dont know what to do, i searched online for answers but nothing. Any help would be awesome

import React, { Component } from 'react'
const fs = require('fs');
export default class WriteFile extends Component {
write = () => { fs.writeFile("file.txt", "Hey there!", function(err) { if(err) { return console.log(err); } console.log("The file was saved!"); });
}
render() { return ( <div> <button className='btn btn-info' onClick={this.write}>scria-ti-as</button> </div> ) }
}

and the error

TypeError: fs.writeFile is not a function
WriteFile._this.write
D:/js/login_reactjs/src/components/WriteFile.js:8
5 | export default class WriteFile extends Component {
6 |
7 | write = () => {
8 | fs.writeFile("file.txt", "Hey there!", function(err) {
9 | if(err) {
10 | return console.log(err);
11 | }
4

2 Answers

fs will not work in the browser. This is by design. fs has been stubbed out See this ticket

You would have better luck using packages that support browsers like browserify or browserFS

3

In browser you should use File API to access files -

Also take a look at It allows you to use nodejs APIs like fs in you "native"-like react app.

Your Answer

Sign up or log in

Sign up using Google Sign up using Facebook Sign up using Email and Password

Post as a guest

By clicking “Post Your Answer”, you agree to our terms of service, privacy policy and cookie policy

You Might Also Like