modificare
La versione di NodeJS 10.12.0ha aggiunto un supporto nativo per entrambi mkdire mkdirSyncper creare il regista padre in modo ricorsivo con l' recursive: trueopzione come segue:
fs.mkdirSync(targetDir, { recursive: true });
E se preferisci fs Promises API, puoi scrivere
fs.promises.mkdir(targetDir, { recursive: true });
Risposta originale
Crea le directory padre in modo ricorsivo se non esistono! ( Zero dipendenze )
const fs = require('fs');
const path = require('path');
function mkDirByPathSync(targetDir, { isRelativeToScript = false } = {}) {
const sep = path.sep;
const initDir = path.isAbsolute(targetDir) ? sep : '';
const baseDir = isRelativeToScript ? __dirname : '.';
return targetDir.split(sep).reduce((parentDir, childDir) => {
const curDir = path.resolve(baseDir, parentDir, childDir);
try {
fs.mkdirSync(curDir);
} catch (err) {
if (err.code === 'EEXIST') { // curDir already exists!
return curDir;
}
// To avoid `EISDIR` error on Mac and `EACCES`-->`ENOENT` and `EPERM` on Windows.
if (err.code === 'ENOENT') { // Throw the original parentDir error on curDir `ENOENT` failure.
throw new Error(`EACCES: permission denied, mkdir '${parentDir}'`);
}
const caughtErr = ['EACCES', 'EPERM', 'EISDIR'].indexOf(err.code) > -1;
if (!caughtErr || caughtErr && curDir === path.resolve(targetDir)) {
throw err; // Throw if it's just the last created dir.
}
}
return curDir;
}, initDir);
}
Utilizzo
// Default, make directories relative to current working directory.
mkDirByPathSync('path/to/dir');
// Make directories relative to the current script.
mkDirByPathSync('path/to/dir', {isRelativeToScript: true});
// Make directories with an absolute path.
mkDirByPathSync('/path/to/dir');
Demo
Provalo!
Spiegazioni
- [AGGIORNAMENTO] Questa soluzione gestisce gli errori specifici della piattaforma come
EISDIRper Mac e EPERMe EACCESper Windows.
- Questa soluzione gestisce sia percorsi relativi che assoluti .
- Nel caso di percorsi relativi, le directory di destinazione verranno create (risolte) nella directory di lavoro corrente. Per risolverli rispetto alla directory corrente dello script, passare
{isRelativeToScript: true}.
- Utilizzo
path.sepe path.resolve(), non solo /concatenazione, per evitare problemi multipiattaforma.
- Usare
fs.mkdirSynce gestire l'errore con try/catchif lanciato per gestire le condizioni di competizione: un altro processo può aggiungere il file tra le chiamate a fs.existsSync()e fs.mkdirSync()e causa un'eccezione.
- L'altro modo per ottenerlo potrebbe essere controllare se esiste un file e crearlo, cioè
if (!fs.existsSync(curDir) fs.mkdirSync(curDir);. Ma questo è un anti-pattern che lascia il codice vulnerabile alle condizioni di gara.
- Richiede Node v6 e versioni successive per supportare la destrutturazione. (Se hai problemi ad implementare questa soluzione con le vecchie versioni di Node, lasciami un commento)
fs.promises.mkdir(path.dirname('/folder1/folder2/file.txt'), {recursive: true}).then(x => fs.promises.writeFile('/folder1/folder2/file.txt', 'content'))