Open In App

Node JS fs.writeFile() Method

Last Updated : 03 Apr, 2025
Comments
Improve
Suggest changes
Like Article
Like
Report

​In Node.js, the fs.writeFile() method is a built-in function used to asynchronously write data to a file. This method allows you to create a new file or overwrite an existing one with the specified content, without blocking the event loop, thus maintaining the non-blocking nature of Node.js applications.

Syntax

fs.writeFile(file, data, options, callback);

Parameters

This method accepts four parameters as mentioned above and described below:

  • file: It is a string, Buffer, URL or file description integer that denotes the path of the file where it has to be written. Using a file descriptor will make it behave similarly to fs.write() method.
  • data: It is a string, Buffer, TypedArray or DataView that will be written to the file.
  • options: It is a string or object that can be used to specify optional parameters that will affect the output. It has three optional parameters:
    • encoding: It is a string value that specifies the encoding of the file. The default value is ‘utf8’.
    • mode: It is an integer value that specifies the file mode. The default value is 0o666.
    • flag: A string value specifies the flag used while writing to the file. The default value is ‘w’.
  • callback: It is the function that would be called when the method is executed.
    • err: It is an error that would be thrown if the operation fails.

Asynchronous vs. Synchronous File Writing

Node.js provides both asynchronous and synchronous methods for writing files:​

  • fs.writeFile(): Asynchronously writes data to a file, allowing other operations to continue while the file is being written.​
  • fs.writeFileSync(): Synchronously writes data to a file, blocking the event loop until the operation completes.

For non-blocking behavior, fs.writeFile() is preferred.​

Implementing fs.writeFile() in a Node.js Application

To use fs.writeFile() in your Node.js application, follow these steps:

Step 1: Initialize a Node.js Project

Open your terminal and create a new directory for your project:

mkdir nodejs
cd nodejs

Step 2:Initialize a new Node.js project:

npm init -y

Create the Application File

touch index.js

Project Structure

NodeProj

Project Structure

In index.js, add the following code to write data to a file asynchronously:

JavaScript
const fs = require('fs');

const data = 'Hello, world!';

fs.writeFile('output.txt', data, 'utf8', (err) => {
  if (err) {
    console.error('Error writing file:', err);
    return;
  }
  console.log('File written successfully!');
});

Step 3: Run the Application

Ensure you have the necessary permissions to write to the directory. Then, run your application:

node index.js

If successful, ‘output.txt’ will be created in your project directory with the content ‘Hello, world!’.

Error Handling with fs.writeFile()

Proper error handling is crucial when working with file operations. The callback function’s err parameter will contain error information if an error occurs. For example:​

fs.writeFile('output.txt', data, 'utf8', (err) => {
  if (err) {
    console.error('Error writing file:', err);
    return;
  }
  console.log('File written successfully!');
});

Best Practices

  • Always Handle Errors: Ensure your callback functions handle errors to prevent application crashes.​
  • Use Appropriate Encoding: Specify the correct encoding to ensure data is written correctly.​
  • Consider File Size: For large files, consider using streams to write data in chunks, preventing high memory usage.

Conclusion

The fs.writeFile() method is a powerful tool for asynchronous file writing in Node.js, contributing to efficient and non-blocking applications. By understanding its usage, syntax, and best practices, you can effectively manage file operations in your projects.


Next Article

Similar Reads