1.首先需要读取文件,所以需要引入node中的文件系统fs.readdir(dir, function(err, files) {});读取一个文件夹,dir:文件夹名,callback参数files:返回dir下所有的文件名fs.statSync(path).isDirectory();判断一个目录是否问一个文件夹const fs = require(‘fs’);2.新建一个子进程利用child_process模块3.将stylus文件实时编译成css文件的命令是stylus -w styl -o css将styl文件夹的.styl文件编译到css文件夹下4.文件夹目录结构具体实现的代码const fs = require(‘fs’)const { exec } = require(‘child_process’) // 创建子进程的方法// 其中最原始的创建方法是spawn,exec,execFile,fork都是对spawan不同程度的封装// exec的实现原理是启动了一个系统shell来解析参数,通俗解释,用cmd来运行一段命令?它还有一个回调函数function readFile(dir, callback) { callback(dir); fs.readdir(dir, (err, files) => { if (files && files.length) { files.forEach(file => { var arr = file.split(’.’); arr.pop(); var path = dir + ‘/’ + file; if (fs.statSync(path).isDirectory()) { readFile(path, callback); } }) } })}readFile(‘styl’, function(dir) { var ls = exec(stylus -w ${dir.replace('styl', './styl')} -o ${dir.replace('styl', './css')}
, (err, stdout, stderr) => { if (err) { console.log(error: ${err}
); } }) ls.stdout.on(“data”, (data) => { console.log(stdout: ${data}
); }) ls.stderr.on(“data”, (data) => { console.log(stderr: ${data}
); }) ls.on(“close”, (code) => { console.log(子进程退出: ${code}
); })})