파일을 삭제하거나, 디렉토리를 삭제하는 방법을 소개합니다.
1. fs.unlink()로 파일 삭제
1.1 fs.unlink()
fs.unlink(file_path, callback)는 인자로 전달된 file_path 파일을 비동기적으로(async) 삭제합니다. 절대경로가 아닌 파일 이름만 전달하면, 현재 작업 경로(Working directory) 아래서 상대경로로 파일을 찾습니다. 삭제가 완료되거나 에러가 발생하면 callback이 전달됩니다.
아래와 같이 파일을 삭제할 수 있습니다.
const fs = require('fs')
fs.unlink('example.txt', err => {
  if (err) throw err;
  console.log('File is deleted.');
});Output:
File is deleted.1.2 fs.unlinkSync()
fs.unlinkSync(file)는 파일을 동기적으로(sync) 삭제합니다. sync이기 때문에 callback 인자는 없으며, 에러가 발생하면 unlinkSync() 안에서 발생합니다.
아래와 같이 동기적으로 파일을 삭제할 수 있습니다.
const fs = require('fs')
fs.unlinkSync('example.txt');
console.log('File is deleted.');Output:
File is deleted.2. fs.rmdir()으로 디렉토리 및 하위 파일 삭제
2.1 fs.rmdir()
fs.rmdir(dir_path, options, callback)는 비어있는 디렉토리나, 파일을 갖고 있는 디렉토리를 비동기적으로(async) 삭제합니다.
- dir_path : 삭제할 폴더 경로 (상대 경로 또는 절대 경로)
 - options : 디렉토리 하위 파일들도 함께 삭제하려면 
recursive: true옵션 추가 - callback : 작업 완료 또는 에러 발생 시 callback 전달됨
 
아래와 같이 test 디렉토리 및 하위 파일들을 모두 삭제할 수 있습니다.
const fs = require('fs')
fs.rmdir('test', { recursive: true }, (err) => {
  if (err) {
    console.log(err)
  } else {
    console.log('Dir is deleted.');
  }
});Output:
Dir is deleted.만약 recursive: true 옵션을 빼고 rmdir()을 호출하면 디렉토리 파일만 삭제할 수 있으며, 삭제하려는 디렉토리에 파일이 있을 때는 에러가 발생합니다.
[Error: ENOTEMPTY: directory not empty, rmdir 'test'] {
  errno: -39,
  code: 'ENOTEMPTY',
  syscall: 'rmdir',
  path: 'test'
}2.2 fs.rmdirSync()
fs.rmdirSync(dir_path, options)는 dir_path의 디렉토리를 동기적으로(sync) 삭제합니다. 위와 동일하게 디렉토리의 하위 파일들도 모두 삭제하려면 recursive: true 옵션을 추가해야 합니다.
const fs = require('fs')
fs.rmdirSync('test', { recursive: true, force: true });
console.log('Dir is deleted.');Output:
Dir is deleted.Related Posts
- ESLint warning, Expected '===' and instead saw '==' eqeqeq
 - Javascript - 현재 날짜/시간을 항상 한국 기준으로 가져오기
 - Javascript - 문자열 사이에 문자 넣기
 - Javascript - 버튼 활성화/비활성화 시키는 방법
 - Javascript - 버튼 이름 변경하기
 - Javascript - div 안의 내용 가져오기, 변경, 추가, 삭제
 - Javascript - <ol>, <ul>에 <li> 동적 추가, 삭제
 - Javascript - div 생성, 추가, 삭제 방법
 - Javascript - 테이블 행(tr) 숨기기, 보이기
 - Javascript - div에 링크 거는 방법
 - Javascript - 자식 요소(element) 개수 확인
 - Javascript - 요소(element) 복사, 붙여넣기
 - Javascript - div에 클릭 이벤트(onclick) 설정 방법
 - Javascript - 체크박스 선택/해제 시, 텍스트박스 활성화/비활성화
 - Javascript - input 숫자만 입력받도록 설정
 - Javascript - 자식 노드 모두 제거
 - Javascript - 체크박스 선택, 해제 방법
 - Javascript - input text 값 가져오기
 - JavaScript - 문자열을 배열(Array)로 변환
 - JavaScript - 특정 문자열의 포함 여부 확인 (includes, 정규표현식)
 - JavaScript - 문자열 비교 방법, 5가지
 - JavaScript - 문자열 바꾸기(replace, 정규식 치환)
 - JavaScript - 배열 전체 출력 (for, forEach, for in, for of)
 - JavaScript - 한번만 실행되는 함수 (once: true)
 - JavaScript - 선택된 checkbox 값 가져오기
 - JavaScript - div, 태그 안의 내용 가져오기
 - JavaScript - element(버튼, div) 보이기 숨기기
 - JavaScript - 숫자를 배열로 변경하는 방법
 - JavaScript - 부모, 형제, 자식 element 찾기
 - JavaScript - 클래스 이름으로 element 찾는 방법
 - JavaScript Array find() 함수
 - JavaScript Array splice() 함수
 - JavaScript의 contains() 함수
 - JavaScript sort() 함수, 예제 소개
 - JavaScript - Set 생성 및 초기화