Ця відповідь не використовує функції блокування, як readdirSync
або statSync
. Він не використовує зовнішніх залежностей і не опиняється в глибині пекла зворотного дзвінка.
Натомість ми використовуємо сучасні зручності JavaScript, такі як Обіцянки та async-await
синтаксиси. І асинхронні результати обробляються паралельно; не послідовно -
const { readdir, stat } =
require ("fs") .promises
const { join } =
require ("path")
const dirs = async (path = ".") =>
(await stat (path)) .isDirectory ()
? Promise
.all
( (await readdir (path))
.map (p => dirs (join (path, p)))
)
.then
( results =>
[] .concat (path, ...results)
)
: []
Я встановлю прикладний пакет, а потім протестую нашу функцію -
$ npm install ramda
$ node
Давайте подивимося, як це працює -
> dirs (".") .then (console.log, console.error)
[ '.'
, 'node_modules'
, 'node_modules/ramda'
, 'node_modules/ramda/dist'
, 'node_modules/ramda/es'
, 'node_modules/ramda/es/internal'
, 'node_modules/ramda/src'
, 'node_modules/ramda/src/internal'
]
Використовуючи узагальнений модуль, Parallel
ми можемо спростити визначення dirs
-
const Parallel =
require ("./Parallel")
const dirs = async (path = ".") =>
(await stat (path)) .isDirectory ()
? Parallel (readdir (path))
.flatMap (f => dirs (join (path, f)))
.then (results => [ path, ...results ])
: []
Parallel
Модуль , використаний вище був зразком , який був витягнутий з набору функцій , призначених для вирішення подібної проблеми. Щоб отримати додаткові пояснення, див. Відповідні запитання та запитання .
require('path').resolve(__dirname, file)