nodejs之glob與globby

glob

glob容許使用規則,從而獲取對應規則匹配的文件。這個glob工具基於javascript.它使用了 minimatch 庫來進行匹配javascript

安裝
npm install glob
引入
const glob = require('glob')
使用

glob方法能夠傳入三個參數:java

一、須要進行匹配的文件的路徑(有點相似於正則表達式)。
二、option可選項,也能夠不填寫。
三、回調函數,回調函數內部能夠返回兩個參數,一個是匹配成功後的結果會返回一個數組,若是沒有匹配上不會報錯會返回一個空數組,一個是失敗後的結果。

示例
glob("**/*.js", options, function (er, files) {
  console.log(files)
})
經常使用匹配規則
    • :匹配單個路徑部分中的0個或多個字符。
  1. :若是在一個路徑的部分,他會匹配零個或多個目錄和子目錄中搜索匹配。
glob("./src/components/**/*.js", function (er, files) {
    console.log(files);
    return files
});
// [ './src/components/index/index.js',
//     './src/components/news/n.js',
//     './src/components/news/news.js' ]
  1. ?:匹配路徑中某部分1個字符
glob("./src/components/**/?.js", function (er, files) {
    console.log(files);
    return files
});
//[ './src/components/news/n.js' ]
  1. !(模式1|模式2|模式3):匹配與所提供的任何模式不匹配的任何內容。和正則表達式的!同樣 案例中的意思是不要n.js 不要index.js,因此就只剩下new.js了
glob("./src/components/**/!(n|index).js", function (er, files) {
    console.log(files)
})
// [ './src/components/news/news.js' ]
  1. [...] :匹配一個字符的範圍,相似於一個正則表達式的範圍。若是範圍的第一個字符是!或者,它匹配任何不在範圍內的字符git

  2. ?(模式1|模式2|模式3):匹配所提供的模式的零或一個事件正則表達式

  3. +(模式1|模式2|模式3):匹配所提供的模式的一個或多個事件。npm

  4. *(a|b|c) :匹配所提供的模式的零個或多個事件。數組

  5. @(pattern|pat*|pat?erN):匹配所提供的模式之一。異步

使用同步語法

在上述案例中使用的都是異步請求,調用回調獲得結果,其實glob也提供了同步返回結果的API ,在這裏我只列舉一個async

let pattern = './src/components/**/@(index|n|news).js';
console.log(glob.sync(pattern));
// [ './src/components/index/index.js',
//     './src/components/news/n.js',
//     './src/components/news/news.js' ]
globby

globby,是基於 glob,並進一步獲得了加強函數

加強特性
  1. Promise 接口
  2. 多模式匹配
  3. 否認模式匹配
  4. 擴展目錄: dir → dir/**/*
  5. 支持 .gitignore
(async () => {
  const paths = await globby(['images','photos'],{
    expandDirectories: true
  });
  console.log(paths);
})();
不想寫了,本身查官方文檔去
相關文章
相關標籤/搜索