Open In App

Node.js fsPromises.opendir() Method

Improve
Improve
Like Article
Like
Save
Share
Report

The fsPromises.opendir() method is defined in the File System module of Node.js. The File System module is basically to interact with the hard disk of the user’s computer. The method is used to asynchronously open a directory.
The fsPromise.opendir() method returns a resolved or rejected promise and hence avoid the callback nesting or callback hell problems that may occur in fs.opendir(). The promise is resolved with ‘fs.Dir’ object, the object itself contains other functions for accessing and closing the directory. In case if the promise is rejected it will be rejected with an error object.
Syntax:  

fs.promises.opendir(path, options)

Parameters: This method accept two parameters as mentioned above and described below:  

  • path: It is an String, Buffer or Url that specifies the path to the directory that has to be open.
  • options: It is an optional parameter that affects the output in someway accordingly provide it to the function call or not. 
    • encoding: It specifies the encoding technique, default is ‘UTF8’
    • bufferSize: It is a number that specifies the number of directory entries that are buffered internally when reading from the directory. High value of bufferSize, ensures good performance but leads to more memory usages.

Return Value: This method returns a promise resolved with ‘fs.Dir’ object, the object itself contains other functions for accessing and closing the directory. In case if the promise is rejected, it will be rejected with an error object.
‘dir’ object methods:  

  • dir.close() method: It asynchronously close the resources of the directory and hence Subsequent attempt to read will result in errors. A Promise is returned that will be resolved after the resource has been closed.
  • dir.closeSync() method: It synchronously close the resources of the directory and hence Subsequent attempt to read will result in errors.
  • dir.path: Returns the path to the directory.
  • dir.read() method: It asynchronously read the next directory entry. After the read is completed, a Promise is returned that will be resolved with an fs.Dirent, or null if there are no more directory read.

Example 1: 

javascript




// Node.js program to demonstrate the  
// fsPromises.opendir() Method
 
// Importing File System module
const fs = require('fs')
 
fs.promises.opendir('./test1')
    .then(dir => {
        console.log('Directory is opened')
 
        // Path to the directory
        console.log(
        `Path to the directory: ${dir.path}`)
 
        // Closing directory
        return dir.close()
    })
 
    .then(() => {
        console.log('Directory closed')
 
        console.log('\nFurther attempt to'
            + ' read sub-directories\n')
 
        // Further attempt to access the
        // directory results in error
        return dir.read()
    })
 
    .then(dirent => {
 
        // Does not execute since directory
        // is closed catch block runs instead
        console.log(dirent)
    })
    .catch(err => {
        console.log('Error, Something went wrong!')
    })


Implementing the same functionality using async-await 

javascript




// Node.js program to demonstrate the  
// fsPromises.opendir() Method
 
// Importing File System module
const fs = require('fs')
 
const readDir = async (path) => {
 
    // Opening directory
    const dir = await fs.promises.opendir(path)
    console.log('Directory is opened')
 
    // Path to the directory
    console.log(`Path to the directory: ${dir.path}`)
 
    // Closing directory
    await dir.close()
    console.log('Directory closed')
 
    console.log('\nFurther attempt '
            + 'to read sub-directories\n')
 
    // Further attempt to access the directory
    // results in error does not execute
    // since directory is closed catch
    // block runs instead
    const subDir = await dir.read()
    console.log(subDir)
}
 
readDir('./test1')
    .catch(err => {
        console.log('Error, Something went wrong!')
    })


Output: 

  Directory is opened
  Path to the directory: test1
  Directory closed

  Further attempt to read sub-directories

  Error, Something went wrong!

Example 2: 

javascript




// Node.js program to demonstrate the  
// fsPromises.opendir() Method
 
// Importing File System module
const fs = require('fs')
 
fs.promises.opendir('./test1')
    .then(dir => {
        console.log('Directory is opened')
 
        // Path to the directory
        console.log(`Path to the directory: ${dir.path}`)
 
        // Reading sub-directories or files
 
        console.log('\nReading sub-directories:\n')
        return dir.read()
    })
 
    .then(dirent => {
        console.log(`Sub-Directory : ${dirent.name}`)
 
        // Reading further sub directories
        return dir.read()
    })
 
    .then(dirent => {
        console.log(`Sub-Directory : ${dirent.name}`)
        return dir.read()
    })
 
    .then(dirent => {
        console.log(`Sub-Directory : ${dirent.name}`)
        return dir.read()
    })
    .then(dirent => {
        console.log(`Sub-Directory : ${dirent.name}`)
        return dir.read()
    })
    .then(dirent => {
        console.log(`Sub-Directory : ${dirent.name}`)
        return dir.read()
    })
    .catch(err => {
        console.log('Error, Something went wrong!')
    })


Implementing the same functionality using async-await 

javascript




// Node.js program to demonstrate the  
// fsPromises.opendir() Method
 
// Importing File System module
const fs = require('fs')
 
const readDir = async (path) => {
 
    // Opening directory
    const dir = await fs.promises.opendir(path)
    console.log('Directory is opened')
 
    // Path to the directory
    console.log(`Path to the directory: ${dir.path}`)
 
    // Reading sub-directories or files
    const subDir1 = await dir.read()
    const subDir2 = await dir.read()
    const subDir3 = await dir.read()
    const subDir4 = await dir.read()
    const subDir5 = await dir.read()
 
    // Printing
    console.log(`Sub-Directory : ${subDir1.name}`)
    console.log(`Sub-Directory : ${subDir2.name}`)
    console.log(`Sub-Directory : ${subDir3.name}`)
    console.log(`Sub-Directory : ${subDir4.name}`)
    console.log(`Sub-Directory : ${subDir5.name}`)
}
 
readDir('./test1')
    .catch(err => {
        console.log('Error, Something went wrong!')
    })


Output: 

  Directory is opened
  Path to the directory: test1

  Reading sub-directories:

  Sub-Directory : example1.txt
  Sub-Directory : example2.txt
  Sub-Directory : example3.txt
  Sub-Directory : example4.txt
  Sub-Directory : null

Reference: https://nodejs.org/dist/latest-v14.x/docs/api/fs.html#fs_fspromises_opendir_path_options



Last Updated : 05 Aug, 2022
Like Article
Save Article
Previous
Next
Share your thoughts in the comments
Similar Reads