Heim  >  Artikel  >  Web-Frontend  >  Detaillierte Erläuterung häufig verwendeter APIs von Prozess-, Pfad- und Dateisystemmodulen in Node.js

Detaillierte Erläuterung häufig verwendeter APIs von Prozess-, Pfad- und Dateisystemmodulen in Node.js

青灯夜游
青灯夜游nach vorne
2021-04-12 10:10:191694Durchsuche

In diesem Artikel werden Ihnen die häufig verwendeten APIs von Prozess-, Pfad- und Dateisystemmodulen in Nodejs vorgestellt. Es hat einen gewissen Referenzwert. Freunde in Not können sich darauf beziehen. Ich hoffe, es wird für alle hilfreich sein.

Detaillierte Erläuterung häufig verwendeter APIs von Prozess-, Pfad- und Dateisystemmodulen in Node.js

Verwandte Empfehlungen: „nodejs Tutorial

Wenn Sie Node für die tägliche Entwicklung verwenden, verwenden Sie einige grundlegende APIs wie Dateisysteme und Pfadoperationen, um das Verständnis und die direkte Verwendung für alle zu erleichtern .

Hier stellen wir nur die am häufigsten verwendeten vor, nicht alle. Wenn Sie umfassendere Informationen sehen möchten, schauen Sie sich einfach die offizielle Dokumentation an.

Versuchen Sie, keinen Unsinn zu reden und mehr Code zu schreiben.

Prozessmodul


Stellen Sie zunächst das Prozessmodul vor, das globale Umgebungsinformationen zum aktuellen Knotenprozess bereitstellt. Wird in späteren APIs verwendet.


// 内置模块,直接使用
const process = require('process');

process.cwd()

Dies ist eine Funktion, die das Verzeichnis zurückgibt, in dem der aktuelle Knotenprozess ausgeführt wird. Ein häufiges Szenario ist beispielsweise:

Ein Knotenmodul A ist über NPM veröffentlicht, wird das Projektmodul A in B verwendet. Wenn Sie Dateien unter dem B-Projekt in A bearbeiten müssen, können Sie process.cwd() verwenden, um B zu erhalten. Code > Der Pfad zum Projekt. <p></p> <pre class="brush:php;toolbar:false">const cwd = process.cwd(); // 输出:/Users/xiaolian/Code/node-api-test</pre> <h3 data-id="heading-2"> <code>A 通过 NPM 发布,项目 B 中使用了模块 A。在 A 中需要操作 B 项目下的文件时,就可以用 process.cwd() 来获取 B 项目的路径。
const args = process.argv.slice(2);

process.argv

在终端通过 Node 执行命令的时候,通过 process.argv 可以获取传入的命令行参数,返回值是一个数组:

  • 0: Node 路径(一般用不到,直接忽略)
  • 1: 被执行的 JS 文件路径(一般用不到,直接忽略)
  • 2~n: 真实传入命令的参数**

所以,我们只要从 process.argv[2] 开始获取就好了。一般都是这样用

console.log(process.platform);

// 'aix'
// 'darwin'  - macOS
// 'freebsd'
// 'linux' - linux
// 'openbsd'
// 'sunos'
// 'win32' - windows

直接获取我们想要的参数。

process.env

返回一个对象,存储当前环境相关的所有信息,一般很少直接用到。

一般我们会在 process.env 上挂载一些变量标识当前的环境。比如最常见的用 process.env.NODE_ENV 区分 developmentproduction。在 vue-cli 的源码中也经常会看到 process.env.VUE_CLI_DEBUG 标识当前是不是一 DEBUG 模式。

这里提一个 webpack 的插件 DefinePlugin,在日常的构建流程中,我们经常会通过这个插件来注入不同的全局变量,从而执行不同的构建流程,并且代码中的 process.env.xxx 会被替换成具体的值,在 Terser 压缩阶段会将 deadCode 移除,优化代码体积。

process.platform

这个用的不多,返回当前系统信息,枚举值如下:

// 内置模块,直接使用
const path = require(&#39;path&#39;);

Path 模块


const dPath = path.join(&#39;template&#39;, &#39;aaa&#39;, &#39;bbb&#39;, &#39;ccc&#39;, &#39;d.js&#39;);
// 输出: template/aaa/bbb/ccc/d.js

Node 中几乎路径相关的操作都会使用这个模块。

这里就说 5 个最常用的:

path.join(...paths)

path.join 作用是将传入的多个路径拼成一个完整的路径。

const pkgPath = path.join(process.cwd(), &#39;./package.json&#39;);
// 输出: /Users/xiaolian/Code/node-api-test/package.json

来看一个非常常见的场景,我们需要获取当前项目的 package.json 文件,就可以这样获取它的路径:

[&#39;package.json&#39;, &#39;README.md&#39;].forEach(fileName => {
  const templateFilePath = path.join(process.cwd(), &#39;template&#39;, fileName);
  console.log(templateFilePath);
});
// 输出: /Users/xiaolian/Code/node-api-test/template/package.json
// 输出: /Users/xiaolian/Code/node-api-test/template/README.md

path.join 可以传入任意个路径,比如:

const dPath = path.resolve(&#39;aaa&#39;, &#39;bbb&#39;, &#39;ccc&#39;, &#39;d.js&#39;);
// 输出:  /Users/xiaolian/Code/node-api-test/aaa/bbb/ccc/d.js

path.resolve(...paths)

path.resovlepath.join 的区别在于它的作用是将传入的多个路径和当前执行路径拼接成一个完整的绝对路径。

假设我现在 index.jsscripts 目录下,然后我在根目录下执行 node scripts/index.js,它的代码如下:

console.log(path.basename(&#39;scripts/index.js&#39;));  // index.js
console.log(path.basename(&#39;scripts/index.js&#39;, &#39;.js&#39;));  // 匹配到 .js,返回 index
console.log(path.basename(&#39;scripts/index.js&#39;, &#39;.json&#39;));  // 没匹配到,返回 index.js

一般情况下,当 path.resolve 的第一个参数为 ./ 时,可以直接理解和 path.join(processs.cwd(), '') 表现一致。

path.basename(path[, ext])

path.basename 返回指定 path 最后一个路径名,其中第二个参数 ext 可选,表示文件扩展名。比如:

console.log(path.basename(&#39;scripts/index.js&#39;));  // scripts
console.log(path.basename(&#39;scripts/hook/index.js&#39;));  // scripts/hook

path.dirname(path)

path.basename 对应,返回指定 pathprocess.argv

🎜🎜Wenn das Terminal den Befehl über Node ausführt, können die eingehenden Befehlszeilenparameter über process.argv abgerufen werden. Der Rückgabewert ist ein Array: 🎜
  • 0: Knotenpfad (im Allgemeinen nicht verwendet, einfach ignorieren)
  • 1: Der ausgeführte JS-Dateipfad (im Allgemeinen nicht verwendet, einfach ignorieren)
  • 2~n: Die Parameter des tatsächlich eingehenden Befehls**
🎜Wir müssen sie also nur von process.argv[2]abrufen > . 🎜Wird normalerweise so verwendet🎜: 🎜
console.log(path.basename(&#39;scripts/index.js&#39;));  // .js
console.log(path.basename(&#39;README.md&#39;));  // .md
🎜Rufen Sie die gewünschten Parameter direkt ab. 🎜

🎜process.env🎜🎜🎜Gibt ein Objekt zurück, das alle Informationen zur aktuellen Umgebung speichert, die selten direkt verwendet werden. 🎜🎜Im Allgemeinen werden wir einige Variablen auf process.env bereitstellen, um die aktuelle Umgebung zu identifizieren. Die häufigste Verwendung ist beispielsweise process.env.NODE_ENV, um Entwicklung und Produktion zu unterscheiden. Im Quellcode von vue-cli sehen Sie häufig process.env.VUE_CLI_DEBUG, der angibt, ob der aktuelle Modus DEBUG ist. 🎜🎜Hier ist ein Webpack-Plugin DefinePlugin🎜 Im täglichen Build-Prozess verwenden wir dieses Plug-In häufig, um verschiedene globale Variablen einzufügen, um verschiedene Build-Prozesse auszuführen, und process.env.xxx im Code wird durch bestimmte Werte ersetzt, deadCode wird während der Terser-Komprimierungsphase entfernt, um die Codegröße zu optimieren. 🎜

🎜process.platform🎜🎜🎜Dies wird nicht oft verwendet. Es gibt die aktuellen Systeminformationen zurück. Der Aufzählungswert lautet wie folgt: 🎜
├── scripts
│   └── index.js
├── src
│   └── index.js
├── package.json
├── README.md

🎜Pfadmodul🎜🎜🎜
const path = require('path');

console.log(path.join('package.json'));
console.log(path.resolve('package.json'));
console.log(path.join('src', 'index.js'));
console.log(path.resolve('src', 'index.js'));
console.log(path.join(process.cwd(), 'package.json'));
console.log(path.resolve('./', 'package.json'));
console.log(__filename);
console.log(__dirname);
🎜Fast 🎜pfadbezogene Vorgänge🎜in Node wird dieses Modul verwenden. 🎜🎜Hier sind die 5 am häufigsten verwendeten: 🎜

🎜path.join(...paths)🎜🎜🎜path.join wird verwendet add Die mehreren übergebenen Pfade werden zu einem vollständigen Pfad zusammengefasst. 🎜
-> node scripts/index.js
package.json
/Users/xiaolian/Code/A/package.json
src/index.js
/Users/xiaolian/Code/A/src/index.js
/Users/xiaolian/Code/A/package.json
/Users/xiaolian/Code/A/package.json
/Users/xiaolian/Code/A/scripts/index.js
/Users/xiaolian/Code/A/scripts
🎜Sehen wir uns ein sehr häufiges Szenario an. Wir benötigen die package.json-Datei des aktuellen Projekts und können den Pfad wie folgt abrufen: 🎜
// 内置模块,直接使用
const fs = require(&#39;fs&#39;);
🎜path.join Sie können bestehen in beliebig vielen Pfaden, zum Beispiel: 🎜
const fs = require('fs');

fs.stat('a.js', function(err, stats) {
  console.log(stats);
});

🎜path.resolve(...paths)🎜🎜🎜path.resovle und path.join Der Unterschied besteht darin, dass seine Funktion darin besteht, die mehreren eingehenden Pfade und den aktuellen Ausführungspfad zu einem vollständigen absoluten Pfad zusammenzufügen. 🎜🎜Angenommen, ich habe jetzt index.js im Verzeichnis scripts und führe dann node scripts/index.js im Stammverzeichnis aus. und sein Der Code lautet wie folgt: 🎜
export interface StatsBase8742468051c85b06f0a0af9e3e506b5c {
  isFile(): boolean;                 // 判断是否是一个文件
  isDirectory(): boolean;            // 判断是否一个目录

  size: T;                           // 大小(字节数)
  atime: Date;                       // 访问时间
  mtime: Date;                       // 上次文件内容修改时间
  ctime: Date;                       // 上次文件状态改变时间
  birthtime: Date;                   // 创建时间
}
🎜Wenn der erste Parameter von path.resolve ./ ist, können Sie path.join im Allgemeinen direkt verstehen (processes .cwd(), '') verhält sich konsistent. 🎜

🎜path.basename(path[, ext])🎜🎜🎜path.basename gibt den letzten Pfad des angegebenen path zurück code> name, wobei der zweite Parameter ext optional ist und die Dateierweiterung darstellt. Beispiel: 🎜
const fs = require('fs');

try {
  const stats = fs.statSync('a.js');
} catch(e) {}

🎜path.dirname(path)🎜🎜🎜 entspricht path.basename und gibt den angegebenen path zurück. Code> am Ende Ein Pfad vor einem Pfadnamen. Zum Beispiel: 🎜<pre class="brush:js;toolbar:false;">console.log(path.basename(&amp;#39;scripts/index.js&amp;#39;)); // scripts console.log(path.basename(&amp;#39;scripts/hook/index.js&amp;#39;)); // scripts/hook</pre><h3 data-id="heading-10"><strong>path.extname(path)</strong></h3> <p>和 <code>path.basename 对应,返回指定 path 最后一个路径名的文件扩展名(含小数点 .)。比如:

console.log(path.basename(&#39;scripts/index.js&#39;));  // .js
console.log(path.basename(&#39;README.md&#39;));  // .md

对比

最后再来对比一下各个路径相关的 API 的区别。

项目 A 的目录结构如下:

├── scripts
│   └── index.js
├── src
│   └── index.js
├── package.json
├── README.md

scripts/index.js 的代码如下:

const path = require('path');

console.log(path.join('package.json'));
console.log(path.resolve('package.json'));
console.log(path.join('src', 'index.js'));
console.log(path.resolve('src', 'index.js'));
console.log(path.join(process.cwd(), 'package.json'));
console.log(path.resolve('./', 'package.json'));
console.log(__filename);
console.log(__dirname);

然后,我们在项目 A 的跟目录下执行 node scripts/index.js,结果如下:

-> node scripts/index.js
package.json
/Users/xiaolian/Code/A/package.json
src/index.js
/Users/xiaolian/Code/A/src/index.js
/Users/xiaolian/Code/A/package.json
/Users/xiaolian/Code/A/package.json
/Users/xiaolian/Code/A/scripts/index.js
/Users/xiaolian/Code/A/scripts

品,仔细品,它们有什么区别。

个人而言,一般还是习惯用 path.join(process.cwd(), 'xxx')

File System 模块


// 内置模块,直接使用
const fs = require(&#39;fs&#39;);

文件系统相关操作的模块,除了 fs 之外,我们还经常用到 fs-extra,后面会介绍。

这个模块在平时的 Node 开发中会被大量使用,这里简单列几个,其它的还是看文档哈:nodejs.org/dist/latest…

fs 模块的 API 默认都是异步回调的形式,如果你想使用同步的方法,有两种解决方法:

  1. 使用 Node 提供的同步 API:xxxSync,也就是在 API 的后面加一个 Sync 后缀,它就是一个同步方法了(具体还是需要查文档哈,是否有提供同步 API)
  2. 包装成一个 Promise 使用

fs.stat(path[, options], callback)

fs.stat() 返回一个文件或者目录的信息。

const fs = require('fs');

fs.stat('a.js', function(err, stats) {
  console.log(stats);
});

其中包含的参数有很多,介绍几个比较常用的:

export interface StatsBase8742468051c85b06f0a0af9e3e506b5c {
  isFile(): boolean;                 // 判断是否是一个文件
  isDirectory(): boolean;            // 判断是否一个目录

  size: T;                           // 大小(字节数)
  atime: Date;                       // 访问时间
  mtime: Date;                       // 上次文件内容修改时间
  ctime: Date;                       // 上次文件状态改变时间
  birthtime: Date;                   // 创建时间
}

一般我们会使用 fs.stat 来取文件的大小,做一些判断逻辑,比如发布的时候可以检测文件大小是否符合规范。在 CLI 中,经常需要获取一个路径下的所有文件,这时候也需要使用 fs.stat 来判断是目录还是文件,如果是目录则继续递归。当然,现在也有更方便的 API 可以完成这个工作。

同步方法

const fs = require('fs');

try {
  const stats = fs.statSync('a.js');
} catch(e) {}

fs.readdir(path[, options], callback)

fs.readdir(path) 获取 path 目录下的文件和目录,返回值为一个包含 filedirectory 的数组。

假设当前目录为:

.
├── a
│   ├── a.js
│   └── b
│       └── b.js
├── index.js
└── package.json

执行以下代码:

const fs = require('fs');

fs.readdir(process.cwd(), function (error, files) {
  if (!error) {
    console.log(files);
  }
});

返回值为:

[ 'a',
  'index.js',
  'package.json' ]

可以看到这里只返回了根目录下的文件和目录,并没有去深度遍历。所以如果需要获取所有文件名,就需要自己实现递归。

同步方法

const fs = require('fs');

try {
  const dirs = fs.readdirSync(process.cwd());
} catch(e) {}

fs.readFile(path[, options], callback)

文件读取的 API,通过 fs.readFile 可以获取指定 path 的文件内容。

入参如下:

  • 第一个参数: 文件路径
  • 第二个参数: 配置对象,包括 encodingflag,也可以直接传如 encoding 字符串
  • 第三个参数: 回调函数

使用方法如下:

const fs = require('fs');
const path = require('path');

fs.readFile(path.join(process.cwd(), 'package.json'), 'utf-8', function (
  error,
  content
) {
  if (!error) {
    console.log(content);
  }
});

如果没传 encoding,则其默认值为 null,此时返回的文件内容为 Buffer 格式。

同步方法

const fs = require('fs');

try {
  fs.readFileSync(path.join(process.cwd(), 'package.json'), 'utf-8');
} catch(e) {}

fs.writeFile(file, data[, options], callback)

对应着读文件 readFilefs 也提供了写文件的 API writeFile,接收四个参数:

  • 第一个参数: 待写入的文件路径
  • 第二个参数: 待写入的文件内容
  • 第三个参数: 配置对象,包括 encodingflag,也可以直接传如 encoding 字符串
  • 第三个参数: 回调函数

使用方法如下:

const fs = require('fs');
const path = require('path');

fs.writeFile(
  path.join(process.cwd(), 'result.js'),
  'console.log("Hello World")',
  function (error, content) {
    console.log(error);
  }
);

同步方法

const fs = require('fs');
const path = require('path');

try {
  fs.writeFileSync(
    path.join(process.cwd(), 'result.js'),
    'console.log("Hello World")',
    'utf-8'
  );
} catch (e) {}

本文主要是总结了一下在开发 Node 时常用的一些 API,后续的文章会带来 Node 常用的一些三方包。

更多编程相关知识,请访问:编程视频!!

Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung häufig verwendeter APIs von Prozess-, Pfad- und Dateisystemmodulen in Node.js. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:juejin.cn. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen