一、简介: node
很简单,写了一个node操做文件的小脚本,主要实现对目标文件夹中内容的复制。还顺带一个按照文件夹或者文件名过滤的功能。webpack
二、应用场景web
适合基于 node 环境的项目,项目打包的时候,配合 webpack 配置,生成须要的线上项目目录,方便快捷。svg
三、 使用说明ui
代码我检验过,应该是没bug的,至于文件过滤,这里只提供一个版本,具体需求你们能够本身改代码,很简单就是过滤代码位置放在哪的问题spa
四、参数及大体思路解析设计
function (srcPath, tarPath, filter = [])
srcPath: String 要复制的文件路径
tarPath: String 复制后存放的文件路径
filter: Array[String] 须要过滤的文件、文件夹名 ps: 注意,只按照名称过滤,不一样目录同名文件不作区分
设计思路: 读取 srcPath 目录内容,先检验是否过滤。而后依次判断类型,若是是文件直接复制到目标目录,若是是文件夹,先再目标目录建立同名文件夹,而后递归。
五、代码code
const fs = require('fs'); const path = require('path'); const copyFile = function (srcPath, tarPath, filter = []) { fs.readdir(srcPath, function (err, files) { console.log(files) if (err === null) { files.forEach(function (filename) { let filedir = path.join(srcPath,filename); let filterFlag = filter.some(item => item === filename) if (!filterFlag) { fs.stat(filedir, function (errs, stats) { let isFile = stats.isFile() if (isFile) { // 复制文件
const destPath = path.join(tarPath,filename); fs.copyFile(filedir, destPath, (err) => { }) } else { // 建立文件夹
let tarFiledir = path.join(tarPath,filename); fs.mkdir(tarFiledir,(err) => { }); copyFile(filedir, tarFiledir, filter) // 递归
} }) } }) } else { if (err) console.error(err); } }) } //使用 copyFile('./public', './public2', ['robots.txt', 'svg'])