• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >JavaScript > ES6实现的遍历目录函数示例

ES6实现的遍历目录函数示例

作者:风之约 字体:[增加 减小] 来源:互联网 时间:2017-05-11

风之约通过本文主要向大家介绍了es6 箭头函数,es6 构造函数,es6回调函数,es6函数,es6中的箭头函数等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

本文实例讲述了ES6实现的遍历目录函数。分享给大家供大家参考,具体如下:

// 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);
  }
});

</div>

希望本文所述对大家ECMAScript程序设计有所帮助。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • ES6实现的遍历目录函数示例
  • ES6中的箭头函数实例详解
  • javascript ES6中箭头函数注意细节小结

相关文章

  • 2017-05-11详解基于angular路由的requireJs按需加载js
  • 2017-05-11JavaScript Date 知识浅析
  • 2017-05-11EasyUI修改DateBox和DateTimeBox的默认日期格式示例
  • 2017-05-11react实现pure render时bind(this)隐患需注意!
  • 2017-05-11jQuery点击弹出层弹出模态框点击模态框消失代码分享
  • 2017-05-11jQuery使用ajax方法解析返回的json数据功能示例
  • 2017-05-11详解用vue-cli来搭建vue项目和webpack
  • 2017-05-11微信小程序 image组件binderror使用例子与js中的onerror区别
  • 2017-05-11详解JavaScript 中getElementsByName在IE中的注意事项
  • 2017-05-11微信小程序 使用腾讯地图SDK详解及实现步骤

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • jQuery展示表格点击变色、全选、删除
    • js for循环倒序输出数组元素的实例
    • 浅谈jquery拼接字符串效率比较高的方法
    • 使用vue实现点击按钮滑出面板的实现代码
    • 微信小程序学习(4)-系统配置app.json详解
    • jQuery多选框选择数量限制方法
    • 大白话讲解JavaScript的Promise
    • jQuery插件FusionCharts实现的3D柱状图效果实例【附demo源码下载】
    • js判断PC端与移动端跳转
    • jQuery中的on与bind绑定事件区别实例详解

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有