Summary
-
NodeJS has
fs
module that helps in managing files -
'fs' module has Promise API, Callback API, and Synchronous API.
-
There are various methods in
fs
from creating, to deleting the files. -
Always use Async methods over sync for improving performance unless and until you have requirements to use sync methods.
Welcome back to my 2nd blog from the series of NodeJS. If you haven't checked my 1st blog, please check here.
Today we will explore the 2nd module (in-built package) of NodeJS – fs
(file system).
We have 3 ways to use fs
module in NodeJS:
-
Promise API
-
callback API
-
Synchronous API
import | mode | return | |
---|---|---|---|
Promise | node:fs/promises | promise based (async) | promise |
Callback | fs | async | error/success or data |
Synchronous | fs | sync | error/success or data |
In this tutorial we will go through the Callback.
What is fs?
NodeJS has native or built-in package fs
. FS stands for filesystem. FS enables devs to create, open, read and write files.
This is an important feature. Developers can do a lot by using FS. Developers will have control over the files.
Where to Use?
-
fs
in configurations. -
Build Scripts
-
Temporary data storage
-
Processing of data before storing in database
How to create a file?
There are 3 ways (methods) to create a new file:
-
open
: open an existing file. -
writeFile
: it will create a file if it's not exist and write content in it. -
appendFile
: it will create a file if it's not exist and append content in it.
How to write content in a file?
- writeFile
-
file name
-
data
-
options: encoding, mode, flag
-
callback: error or success
// Example: Callback API const fs = require('fs'); fs.writeFile('logs.txt','hello', 'utf8' (err) => { if(err) { console.log('error') } else{ console.log('data saved') } }); // Example: Promise API import { writeFile } from 'node:fs/promises'; (async function main() { try { await writeFile( "logs.txt",'hello') console.log("The written file has" + " the following contents:"); } catch (err) { console.error(err); } })();
2 . open
-
file name
-
mode
-
callback: error or success
const fs = require('fs'); // Callback API fs.open('logs.txt', 'w', (err) => { if(err) { console.log('error') } else{ console.log('file open') } }); // Promise API import { open } from 'node:fs/promises'; (async function main() { try { await open( "logs.txt") console.log("The file has been open"); } catch (err) { console.error(err); } })();
3 . appendFile
-
file name
-
data
-
options: encoding, mode, flag
-
callback: error or success
// callback API fs.appendFile('logs.txt', 'new text', 'utf8' , (err) => { if(err) { console.log('error') } else{ console.log('data added') } }); // Promise API import { appendFile } from 'node:fs/promises'; (async function main() { try { await appendFile("logs.txt", 'hello'); console.log("The file has been open"); } catch (err) { console.error(err); } })();
How to read content from a file?
So far we saw how to create and write content to a file. We can also read the file's content.
read
-
file name
-
encoding options: utf8, utf16, base ,etc.
-
callback: error or data
fs.readFile('logs.txt', (err,data) => { if(err) { console.log('error') } else{ console.log(data); // this will return buffer console.log(data.toString()); // convert the buffer to string } });
Code:
// import package const fs = require('fs') // read a file const readfile = fs.readFile('logs.txt', 'utf-8'); console.log(readfile); // write content of a file const writefile = fs.writeFile('logs.txt', 'hello'); const readfile = writefile.readFile(writefile) console.log(readfile); // append content const readfile = fs.appendFile('logs.txt', 'utf-8'); console.log(readfile); // rename const logs = fs.createFile('logs.txt'); fs.rename('logs.txt', 'userlogs.txt', () => { console.log('done') }); // delete const logs = fs.createFile('logs.txt'); fs.unlink('logs.txt', () => { console.log('deleted') });
Important
-
Content in the file would be either string, buffer, or text. Not, object
-
writeFile will overwrite the content. Hence, use appendFile
sync vs async
You will see that there are 2 methods in fs
: readfile
and readFileSync
. readFile
is async operation. It's a blocking operation and will impact the performance. Hence, prefer to use readFile
over readFileSync
unless and until you don't have any requirement.