About fs.read() & fs.write()

fs.read() & fs.write() are different from other fs methods in that their callbacks are called with 3 arguments instead of the usual 2 arguments.

If you’re using them with callbacks, they will behave as usual. However, their promise usage is a little different. fs-extra promisifies these methods like util.promisify() (only available in Node 8+) does.

Here’s the example promise usage:

fs.read()

  1. // Basic promises
  2. fs.read(fd, buffer, offset, length, position)
  3. .then(results => {
  4. console.log(results)
  5. // { bytesRead: 20, buffer: <Buffer 0f 34 5d ...> }
  6. })
  7. // Async/await usage:
  8. async function example () {
  9. const { bytesRead, buffer } = await fs.read(fd, Buffer.alloc(length), offset, length, position)
  10. }

fs.write()

  1. // Basic promises
  2. fs.write(fd, buffer, offset, length, position)
  3. .then(results => {
  4. console.log(results)
  5. // { bytesWritten: 20, buffer: <Buffer 0f 34 5d ...> }
  6. })
  7. // Async/await usage:
  8. async function example () {
  9. const { bytesWritten, buffer } = await fs.write(fd, Buffer.alloc(length), offset, length, position)
  10. }