nodejs 遍历目录结构

nodejs 的递归算法的应用。

var fs = require("fs")

function walk(dir) {
    var children = []
    fs.readdirSync(dir).forEach(function(filename){
        var path = dir+"/"+filename
        var stat = fs.statSync(path)
        if (stat && stat.isDirectory()) {
            children = children.concat(walk(path))
        }
        else {
            children.push(path)
        }
    })

    return children
}

walk() //遍历目录,将所有目录放入children数组中。

fs.readdirSync 同步读取目录的方法,fs是nodejs的模块。

 fs.readdirSync(dir).forEach(function(filename){})
对每一个dir (类似 ‘/bar/foo’,_dirname),下面的每一个filename.

比如有这样的结构:

- /home/user/
    - foo/
        x.js
    - bar/
        y.js
    z.css
foo/bar/z.css都是当前dir(/home/user)的下一级filename.

  var path = dir+"/"+filename
foo/bar/z.css分别转为 :

/home/user/foo

/home/user/bar

/home/user/z.css

 var stat = fs.statSync(path)
        if (stat && stat.isDirectory()) {
stat 是fs的文件属性,包含文件的大小啊,创建时间,是否是目录等等

当该路径存在并且是目录的时候,递归:

children = children.concat(walk(path))
即是:

/home/user/foo的时候,继续递归找他的下级目录。

这里注意concat与push的区别:

concat  不改变原数组,假如a=[1,2,3]加入的是[4,5]的话,最后变为·1,2,3,4,5」

push 怎会变为[1,2,3,[4,5]]


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值