首先,大体先看一下要生成的目录树的样子
├─ hw
│ ├─dirtree.js
│ └─ test.js
├─test.js
└─ url.js
大体思路分析
1、获取目标文件夹的目录内容
2、将文件或者文件夹进行划分
3、将文件或者文件夹进行打印 命令行console.log()
4、中间要用到的关键就是读取文件夹,和设置深度,每次递归都让其深度加一,就可以区别开一级二级三级了
文件夹再次遍历 deep 1 ├─ …… deep2 │ ├─ deep3│ │ ├─
打印当前目录树
代码实现
const fs=require('fs');
const path=require('path');
let target=path.join(__dirname,'../');
function loadTree(target,deep){
let prev=new Array(deep).join(' |');
let dirinfo=fs.readdirSync(target);
let files=[];
let dirs=[];
for (let i = 0; i < dirinfo.length; i++) {
let state= fs.statSync(path.join(target,dirinfo[i]));
if (state.isFile()) {
files.push(dirinfo[i])
}else{
dirs.push(dirinfo[i])
}
}
for (let i = 0; i < dirs.length; i++) {
console.log(`${prev} ├─ ${dirs[i]}`)
let nextPath=path.join(target,dirs[i])
let nextdeep=deep+1;
loadTree(nextPath,nextdeep)
}
for (let i =files.length-1 ; i >= 0; i--) {
if (i===0) {
console.log(`${prev} └─ ${files[i]}`)
}else{
console.log(`${prev} ├─ ${files[i]}`)
}
}
}
loadTree(target,1);