Bird
Raised Fist0
Node.jsframework~5 mins

path.basename and path.dirname in Node.js

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Introduction

These functions help you get parts of a file path easily. basename gets the file name, and dirname gets the folder path.

When you want to get just the file name from a full file path.
When you need to find the folder containing a file.
When organizing files and you want to separate folder names from file names.
Syntax
Node.js
const path = require('path');

path.basename(pathString[, ext])
path.dirname(pathString)

pathString is the full path you want to work with.

ext in basename is optional and removes the file extension if given.

Examples
Gets the file name file.txt from the full path.
Node.js
const path = require('path');

const fileName = path.basename('/home/user/docs/file.txt');
console.log(fileName);
Gets the folder path /home/user/docs from the full path.
Node.js
const path = require('path');

const folder = path.dirname('/home/user/docs/file.txt');
console.log(folder);
Gets the file name without extension: file.
Node.js
const path = require('path');

const fileNameNoExt = path.basename('/home/user/docs/file.txt', '.txt');
console.log(fileNameNoExt);
Sample Program

This program shows how to get the file name, folder path, and file name without extension from a full file path.

Node.js
const path = require('path');

const fullPath = '/users/alex/projects/app/index.js';

const fileName = path.basename(fullPath);
const folderName = path.dirname(fullPath);
const fileNameNoExt = path.basename(fullPath, '.js');

console.log('File name:', fileName);
console.log('Folder path:', folderName);
console.log('File name without extension:', fileNameNoExt);
OutputSuccess
Important Notes

These functions work with both Windows and Unix-style paths.

Use basename with the extension argument to remove file extensions easily.

Summary

path.basename gets the file name from a full path.

path.dirname gets the folder path from a full path.

They help split paths into useful parts for file handling.

Practice

(1/5)
1. What does path.basename return when given a full file path?
easy
A. The folder path only
B. The file name with extension
C. The full path unchanged
D. The file extension only

Solution

  1. Step 1: Understand path.basename purpose

    This function extracts the last part of a path, which is usually the file name with its extension.
  2. Step 2: Compare with other path parts

    Unlike path.dirname which returns the folder path, path.basename returns the file name part.
  3. Final Answer:

    The file name with extension -> Option B
  4. Quick Check:

    basename = file name [OK]
Hint: basename gives file name, dirname gives folder path [OK]
Common Mistakes:
  • Confusing basename with dirname
  • Expecting basename to return folder path
  • Thinking basename returns file extension only
2. Which of the following is the correct syntax to get the directory name from a path using Node.js path module?
easy
A. path.getDirName('/home/user/file.txt')
B. path.getdirname('/home/user/file.txt')
C. path.dirName('/home/user/file.txt')
D. path.dirname('/home/user/file.txt')

Solution

  1. Step 1: Recall correct method name in path module

    The correct method to get the directory name is dirname, all lowercase.
  2. Step 2: Check method call syntax

    It is called as path.dirname(pathString), so path.dirname('/home/user/file.txt') matches exactly.
  3. Final Answer:

    path.dirname('/home/user/file.txt') -> Option D
  4. Quick Check:

    dirname method syntax = path.dirname('/home/user/file.txt') [OK]
Hint: Use exact method name dirname() with lowercase letters [OK]
Common Mistakes:
  • Capitalizing method names incorrectly
  • Using getDirName or similar incorrect names
  • Misspelling dirname as dirName
3. What will be the output of the following code?
const path = require('path');
const fullPath = '/var/www/html/index.html';
console.log(path.basename(fullPath));
console.log(path.dirname(fullPath));
medium
A. index.html
/var/www/html
B. /var/www/html/index.html
index.html
C. index
/var/www/html/index.html
D. /var/www/html
index.html

Solution

  1. Step 1: Evaluate path.basename(fullPath)

    This returns the file name with extension, which is index.html.
  2. Step 2: Evaluate path.dirname(fullPath)

    This returns the folder path containing the file, which is /var/www/html.
  3. Final Answer:

    index.html
    /var/www/html
    -> Option A
  4. Quick Check:

    basename = file name, dirname = folder path [OK]
Hint: basename prints file, dirname prints folder path [OK]
Common Mistakes:
  • Swapping basename and dirname outputs
  • Expecting basename to return folder path
  • Confusing output order
4. Identify the error in this code snippet:
const path = require('path');
const filePath = '/usr/local/bin/node';
console.log(path.baseName(filePath));
console.log(path.dirname(filePath));
medium
A. Incorrect method name 'baseName' should be 'basename'
B. Missing import of 'path' module
C. Wrong argument type passed to dirname
D. No error, code runs fine

Solution

  1. Step 1: Check method names used

    The method path.baseName is incorrect because the correct method is all lowercase basename.
  2. Step 2: Verify other parts

    The path module is imported correctly and dirname usage is correct, so no other errors.
  3. Final Answer:

    Incorrect method name 'baseName' should be 'basename' -> Option A
  4. Quick Check:

    Method names are case-sensitive [OK]
Hint: Check method name spelling and case carefully [OK]
Common Mistakes:
  • Using wrong case in method names
  • Assuming method names are case-insensitive
  • Ignoring error messages about undefined functions
5. Given the path /home/user/docs/letter.txt, how can you use path.basename and path.dirname together to print:
Folder: /home/user/docs
File: letter.txt
Which code snippet achieves this?
hard
A. console.log(`Folder: ${path.dirname(path.basename(filePath))}`); console.log(`File: ${path.basename(path.dirname(filePath))}`);
B. console.log(`Folder: ${path.basename(filePath)}`); console.log(`File: ${path.dirname(filePath)}`);
C. console.log(`Folder: ${path.dirname(filePath)}`); console.log(`File: ${path.basename(filePath)}`);
D. console.log(`Folder: ${filePath.dirname()}`); console.log(`File: ${filePath.basename()}`);

Solution

  1. Step 1: Use path.dirname to get folder path

    Calling path.dirname(filePath) returns the folder path /home/user/docs.
  2. Step 2: Use path.basename to get file name

    Calling path.basename(filePath) returns the file name letter.txt.
  3. Step 3: Combine in template strings for output

    Using template literals with these calls prints the desired output lines.
  4. Final Answer:

    console.log(`Folder: ${path.dirname(filePath)}`); console.log(`File: ${path.basename(filePath)}`); -> Option C
  5. Quick Check:

    dirname = folder, basename = file [OK]
Hint: dirname for folder, basename for file name [OK]
Common Mistakes:
  • Swapping basename and dirname calls
  • Trying to call basename/dirname on strings directly
  • Using incorrect method chaining