码迷,mamicode.com
首页 > 其他好文 > 详细

写一个ES6 的遍历目录函数

时间:2016-08-21 19:42:58      阅读:176      评论:0      收藏:0      [点我收藏+]

标签:

// npm init
// npm install koa --save-dev
// node --harmony app.js
const fs = require(‘fs‘);

var eachDir = (() => {
    let queue = [];
    var eachFiles = (options) => {
        if (queue.length) {
            let path = queue.shift();
            fs.readdir(path, (err, files) => {
                if (err) {
                    options.fail(err);
                    return;
                }

                files.forEach((file, i) => {
                    let url = path + ‘/‘ + file;
                    let stats = fs.statSync(url);

                    if (stats.isDirectory()) {
                        queue.push(url);
                    } else {
                        options.callback && options.callback.call(stats, {
                            name: file,
                            size: stats.size,
                            path: url
                        });
                    }
                });

                eachFiles(options);
            });
        } else {
            options.done();
        }
    };

    return (path, options) => {
        let stats = fs.statSync(path);
        if (stats.isDirectory()) {
            queue.push(path);    
        }
        eachFiles(options);
    };
})();

let total = 0, fileTypes = {};
eachDir(‘./‘, {
    callback(file) {
        let ret = file.name.match(/\.(\w+$)/);
        if (ret) {
            if (!fileTypes[ret[0]]) {
                fileTypes[ret[0]] = 0;
            }
            fileTypes[ret[0]] += 1;
        }
        // console.log(file);
        total++;
    },
    done() {
        console.log(total, fileTypes);
        fs.writeFile(‘./result.txt‘, JSON.stringify(fileTypes), (err) => {
            if (err) throw err;
            console.log(‘done‘);
        });
    },
    fail(err) {
        console.log(err);
    }
});

写一个ES6 的遍历目录函数

标签:

原文地址:http://www.cnblogs.com/zhoulingfeng/p/5793256.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!