Heim > Web-Frontend > js-Tutorial > Eine kurze Diskussion über Modulspezifikationen in Nodejs

Eine kurze Diskussion über Modulspezifikationen in Nodejs

青灯夜游
Freigeben: 2021-06-09 10:47:50
nach vorne
2091 Leute haben es durchsucht

Dieser Artikel vermittelt Ihnen ein detailliertes Verständnis der Modulspezifikationen in Nodejs. Es hat einen gewissen Referenzwert. Freunde in Not können sich darauf beziehen. Ich hoffe, es wird für alle hilfreich sein.

Eine kurze Diskussion über Modulspezifikationen in Nodejs

Die Modulspezifikation ist die Grundlage für den Aufbau einer umfangreichen Node.js-Anwendung, daher ist sie auch die CommonJS-Modulspezifikation. [Empfohlenes Lernen: „nodejs-Tutorial“]

CommonJS-Modulspezifikation

In der Vergangenheit war die einzige Möglichkeit, JS-Dateien zu laden, das Tag <script></script>. Was ist das Problem? damit? <script></script> 标签引入,这个会有什么问题呢?

  • 脚本变多时,需要手动管理加载的顺序;脚本越多就越难管理。
  • 不同脚本之间的逻辑调用,需要通过全局变量的方式。
  • 没有 html 的时候怎么引用 JS 文件呢?这个例子就是 Node.js。

于是 Node.js 就有了 CommonJS 模块规范,而 Webpack 也是兼容了 CommonJS 的写法,让我们可以用 CommonJS 规范来写前端代码。

CommonJS 模块规范是 JavaScript 社区发起的,它在 Node.js 上得到应用并推广,后续也影响到了浏览器端 JavaScript。

require

require 是 CommonJS 模块规范的 API,用来引入要使用的文件。比如引入 lib.js

require(&#39;./lib&#39;);
Nach dem Login kopieren

require 默认返回一个空对象;新建两个文件,文件内容如下:

// lib.js
console.log('this is lib');

// index.js
console.log('start require')
var lib = require(&#39;./lib&#39;); // 默认返回一个空对象
console.log('end require', lib);
Nach dem Login kopieren

来运行看看:node index.js

Eine kurze Diskussion über Modulspezifikationen in Nodejs

它也是可以通过 exports 来挂载一些属性的:字符串、函数、对象等类型的数据。

lib.js 添加一些代码

console.log(&#39;this is lib&#39;)

exports.hello = "world"
exports.add = function (a, b) {
  return a + b;
}
exports.obj = { hello: "Node" }
Nach dem Login kopieren

Eine kurze Diskussion über Modulspezifikationen in Nodejs

看来在 CommonJS 模块规范下,它是默认有一个 exports 这样的空对象的。

那既然 require 返回这样一个对象,那么修改和添加其中的属性会怎么样呢?

// index.js
// 既然 require 返回一个对象,那么修改和添加属性会怎么样呢?
lib.hello = &#39;node&#39;;
lib.update = &#39;1234&#39;;
Nach dem Login kopieren
// lib.js
setTimeout(function() {
  console.log(exports)
}, 500)
Nach dem Login kopieren

Eine kurze Diskussion über Modulspezifikationen in Nodejs

可以看到,在 lib.js 加了一个 500ms 之后打印的内容是改变了的。所以通过 exports 输出的时候要注意这个拷贝的问题。可能有些同学会看到过这样的一段话:CommonJS 模块输出的是一个值的浅拷贝,ES6 模块输出的是值的引用。那么这是怎么回事呢?

原来 require 还可以通过 module.exports 的方式返回数据,而且数据类型是不限的,例如返回一个函数:

// lib.js
console.log(&#39;this is lib&#39;)

exports.hello = "world"
exports.add = function (a, b) {
  return a + b;
}
exports.obj = { hello: "Node" }
// setTimeout(function() {
//   console.log(exports)
// }, 500)
module.exports = function minus(a, b) {
  return a - b;
}
Nach dem Login kopieren

Eine kurze Diskussion über Modulspezifikationen in Nodejs

可以看到:lib 返回输出的 minus 函数。

require 一个模块时,module.exports 的优先级要高于 exports,如果指定了 module.exports,那么就会使用 module.exports 指定的对象,如果没有指定 module.exports,就会使用 exports 对象。

npm

npm 相信大家都不陌生,那这里就只是简单介绍一下吧。

npm 是 Node.js 的包管理工具,安装 Node.js 的时候都会自带有 npm 的。而包则是别人写的 Node.js 模块,我们平时开发都会经常用到一些别人开发出来放到 Node.js 服务器上面的包。

npm 初始化:npm init,初始化的时候一直回车就好,之后会生成一个 package.json 文件;或者执行命令 npm init -y,这样就是生成一个默认的 package.json 文件,里面的属性和执行 npm init 一直回车是一样的。

Eine kurze Diskussion über Modulspezifikationen in Nodejs

package.json

  • Wenn mehr Skripte vorhanden sind, müssen Sie die Ladereihenfolge manuell verwalten; je mehr Skripte, desto schwieriger ist die Verwaltung.
  • Logische Aufrufe zwischen verschiedenen Skripten müssen über globale Variablen erfolgen.
  • Wie referenziere ich JS-Dateien, wenn kein html vorhanden ist? Dieses Beispiel ist Node.js.

Node.js verfügt also über die CommonJS-Modulspezifikation, und Webpack ist auch mit der CommonJS-Schreibmethode kompatibel, sodass wir die CommonJS-Spezifikation zum Schreiben von Front-End-Code verwenden können. 🎜🎜Die CommonJS-Modulspezifikation wurde von der JavaScript-Community initiiert. Sie wurde auf Node.js angewendet und beworben und wirkte sich anschließend auf browserseitiges JavaScript aus. 🎜

🎜require🎜🎜🎜require ist die API der CommonJS-Modulspezifikation, die zur Einführung der zu verwendenden Dateien verwendet wird. Importieren Sie beispielsweise lib.js: 🎜
{
  "name": "node",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "",
  "license": "ISC"
}
Nach dem Login kopieren
Nach dem Login kopieren
🎜require gibt standardmäßig ein leeres Objekt zurück; erstellen Sie zwei neue Dateien mit dem folgenden Inhalt: 🎜
npm install -g cnpm --registry=https://registry.npm.taobao.org
Nach dem Login kopieren
Nach dem Login kopieren
🎜Lass es uns ausführen: < code> node index.js🎜🎜1 .png🎜🎜Es können auch einige Attribute durch Exporte bereitgestellt werden: Zeichenfolgen, Funktionen, Objekte und andere Datentypen. 🎜🎜Fügen Sie etwas Code in lib.js hinzu🎜
npm install express --registry=https://registry.npm.taobao.org
Nach dem Login kopieren
Nach dem Login kopieren
🎜Eine kurze Diskussion über Modulspezifikationen in Nodejs🎜🎜Es scheint, dass es gemäß der CommonJS-Modulspezifikation standardmäßig ein leeres Objekt wie exports hat. 🎜🎜Da require ein solches Objekt zurückgibt, was passiert, wenn Sie seine Eigenschaften ändern und hinzufügen? 🎜rrreeerrreee🎜Eine kurze Diskussion über Modulspezifikationen in Nodejs🎜🎜 Sie können sehen, dass sich der gedruckte Inhalt geändert hat, nachdem 500ms zu lib.js hinzugefügt wurde. Daher müssen Sie beim Exportieren über exports auf dieses Kopierproblem achten. Einige Schüler haben möglicherweise diesen Absatz gesehen: 🎜Das CommonJS-Modul gibt eine flache Kopie eines Werts aus, während das ES6-Modul einen Verweis auf den Wert ausgibt🎜. Was ist denn los? 🎜🎜Es stellt sich heraus, dass require auch Daten über module.exports zurückgeben kann und der Datentyp nicht eingeschränkt ist. Beispielsweise ist die Rückgabe einer Funktion: 🎜rrreee🎜Eine kurze Diskussion über Modulspezifikationen in Nodejs🎜🎜Sie können sehen: < code>lib Die minus-Funktion, die die Ausgabe zurückgibt. 🎜🎜Das heißt, wenn require ein Modul ist, hat module.exports eine höhere Priorität als exports🎜, wenn module angegeben ist. exports, dann wird das durch module.exports angegebene Objekt verwendet. Wenn module.exports nicht angegeben ist, wird exports verwendet Objekt verwendet. 🎜

🎜npm🎜🎜🎜npm Ich glaube, jeder kennt es, deshalb hier nur eine kurze Einführung. 🎜🎜npm ist das Paketverwaltungstool für Node.js. Bei der Installation von Node.js wird es mit npm geliefert. Pakete sind von anderen geschriebene Node.js-Module. In unserer täglichen Entwicklung verwenden wir häufig einige von anderen entwickelte und auf dem Node.js-Server platzierte Pakete. 🎜🎜npm Initialisierung: npm init, drücken Sie während der Initialisierung einfach die Eingabetaste, dann wird eine package.json-Datei generiert oder führen Sie den Befehl aus npm init -y, dadurch wird eine Standarddatei package.json generiert. Die darin enthaltenen Eigenschaften sind dieselben wie beim Ausführen von npm init und Drücken der Eingabetaste. 🎜🎜Eine kurze Diskussion über Modulspezifikationen in Nodejs🎜🎜< Der Inhalt der Datei code>package.json lautet wie folgt: 🎜
{
  "name": "node",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "",
  "license": "ISC"
}
Nach dem Login kopieren
Nach dem Login kopieren
  • 下载安装依赖包 <packageName>npm install <packageName>;如果想要全局安装则添加 -gnpm install <packageName> -g。如安装 glob 包:npm install glob
  • 卸载依赖包的命令是 npm uninstall <packageName>

比如安装 express 包,安装成功会生成一个 node-modules 文件夹,我们下载的包就放在这个文件里面:

Eine kurze Diskussion über Modulspezifikationen in Nodejs

如果使用 npm 安装依赖包的速度很慢,可以使用淘宝镜像 cnpm 来安装,镜像是指它把国外 npm 的包做一层复制然后映射到国内的服务器上面,这样不用山长水远去国外拉包,速度会快很多。

安装 cnpm

npm install -g cnpm --registry=https://registry.npm.taobao.org
Nach dem Login kopieren
Nach dem Login kopieren

cnpm 的使用和 npm 类似:cnpm install <packageName>

那如果你觉得 cnpm 不够正宗,不想长期使用,但有些包下载又确实慢了,可以临时使用镜像,比如安装 express

npm install express --registry=https://registry.npm.taobao.org
Nach dem Login kopieren
Nach dem Login kopieren

--registry= 是指定下载地址的意思,例如一些公司可能有自己的依赖包服务器,那么可以通过将这个地址指向公司的服务器地址来更快的下载依赖包。

cnpm 本身其实是 npm 的一个别名,使用 cnpm 的时候会自动帮我们加上后面的参数 --registry=https://registry.npm.taobao.org,然后通过镜像地址来下载依赖包。

另外,npm 使用遇到问题可以登录 官网 寻找解决办法:

Eine kurze Diskussion über Modulspezifikationen in Nodejs

总结

  • Node.js 的模块规范就是 CommonJS 模块规范。
  • CommonJS 模块规范通过 require() 加载模块,默认返回一个对象,可以通过设置 exportsmodule.exports 设置模块返回的数据。
  • Node.js 的包管理工具是 npm,可通过使用镜像 cnpm 来提高下载速度。

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

Das obige ist der detaillierte Inhalt vonEine kurze Diskussion über Modulspezifikationen in Nodejs. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:juejin.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage