await
ECMAScript de niveau supérieur 🎜, le mot-clé await
peut être utilisé au niveau supérieur du module (en dehors de la fonction asynchrone) ; 🎜🎜import .meta.url
: nodejs
renvoie le chemin absolu du protocole file://
local du module, par exemple : file://home/ user/main.js
, s'il y a un autre fichier test.js
dans le module, alors le chemin de test.js
est nouvelle URL ( 'test.js', import.meta.url)
; 🎜🎜nouvelle URL
: Générer un objet du protocole file:
(pour la plupart des fonctions du module fs
, path ou filename
peut être transmis en tant qu'objet en utilisant le protocole file:
). 🎜2. Implémentez 🎜rrreee🎜 via la méthode createRequire
du module module
intégré de nodejs<.> La méthode est implémentée sur la base de la méthode createRequire
fournie par nodejs
. 🎜🎜
🎜3. La bibliothèque tierce de code source de 24 lignes load-json-file
🎜🎜🎜load-json-file🎜 a été accidentellement découverte par moi sur le site npm. Le code source ne comporte que 24 lignes, comme suit : 🎜rrreee🎜🎜load-json-file source code🎜 Dans l'ensemble, c'est relativement simple, mais il existe également de nombreux points de connaissances qui peuvent être appris en profondeur. 🎜🎜Pour plus de connaissances sur les nœuds, veuillez visiter : 🎜tutoriel Nodejs🎜 ! ! 🎜" >1 Lisez le fichier json
via fs<.> système de fichiers 🎜rrreee🎜Explication : 🎜🎜await
: Selon Proposition await
ECMAScript de niveau supérieur 🎜, le mot-clé await
peut être utilisé au niveau supérieur du module (en dehors de la fonction asynchrone) ; 🎜🎜import .meta.url
: nodejs
renvoie le chemin absolu du protocole file://
local du module, par exemple : file://home/ user/main.js
, s'il y a un autre fichier test.js
dans le module, alors le chemin de test.js
est nouvelle URL ( 'test.js', import.meta.url)
; 🎜🎜nouvelle URL
: Générer un objet du protocole file:
(pour la plupart des fonctions du module fs
, path ou filename
peut être transmis en tant qu'objet en utilisant le protocole file:
). 🎜2. Implémentez 🎜rrreee🎜 via la méthode createRequire
du module module
intégré de nodejs<.> La méthode est implémentée sur la base de la méthode createRequire
fournie par nodejs
. 🎜🎜
🎜3. La bibliothèque tierce de code source de 24 lignes load-json-file
🎜🎜🎜load-json-file🎜 a été accidentellement découverte par moi sur le site npm. Le code source ne comporte que 24 lignes, comme suit : 🎜rrreee🎜🎜load-json-file source code🎜 Dans l'ensemble, c'est relativement simple, mais il existe également de nombreux points de connaissances qui peuvent être appris en profondeur. 🎜🎜Pour plus de connaissances sur les nœuds, veuillez visiter : 🎜tutoriel Nodejs🎜 ! ! 🎜



Une brève analyse de la façon dont nodejs charge les fichiers json dans le module ECMAScript
Comment charger des fichiers json dans node dans le module ECMAScript》L'article suivant vous présentera comment nodejs charge les fichiers json dans le module ECMAScript. J'espère qu'il vous sera utile !
Après avoir lu cet article, vous apprendrez :
1. nodejs Comment charger et analyser les fichiers json
2. Comment le module fs lit les fichiers json
3.
3. Apprenez une nouvelle URL()
4. Apprenez la bibliothèque de fichiers Load-json
Comme nous le savons tous, si vous chargez json
dans le module CommonJS
> Fichier. , chargez-le simplement directement via la fonction require()
, et vous pourrez obtenir l'objet json
. CommonJS模块
中加载json
文件,只需通过require()
函数直接加载即可,即能得到json
对象。
但是在ECMAScript模块
中直接加载json文件,会报错,报错如下:
首先,先启用
ESM
模式,其实官方文档(http://nodejs.cn/api/esm.html#introduction)中也有说明:Node.js 默认将 JavaScript 代码视为 CommonJS 模块。 作者可以通过
.mjs
文件扩展名、package.json
"type"
字段、或--input-type
标志告诉 Node.js 将 JavaScript 代码视为 ECMAScript 模块
那怎么才能在ECMAScript模块
加载json
文件呢?其实是有两种方案的:
假设现在有一个json文件:test.json
文件内容如下:
{ "name": "project" }
接下来,在index.js
中引入test.json
:
一、 通过 fs
文件系统读取 json
文件
import { readFile } from "fs/promises"; // 以promise的方式引入 readFile API const json = JSON.parse( await readFile(new URL('./test.json', import.meta.url)) ) console.log('[json1]:', json); // 输出: { "name": "project" }
解释:
await
: 根据 ECMAScript 顶层 await
提案,await
关键字可用于模块内的顶层(异步函数之外);
import.meta.url
:nodejs
中返回模块在本地的file://
协议的绝对路径,例如:file://home/user/main.js
, 如果模块中还有另外一个文件test.js
,那么test.js
的路径就是new URL('test.js', import.meta.url)
;
new URL
: 生成file:
协议的对象(对于大多数 fs
模块函数,path
或 filename
参数可以作为使用 file:
协议的对象传入)。
二、 通过nodejs
内置module
模块的createRequire
方法实现
import { createRequire } from "module"; const require = createRequire(import.meta.url); const json = require('./test.json'); console.log('[json2]:', json); // 输出: { "name": "project" }
这种方法是根据nodejs
提供的createRequire
方法实现。
三、 24行源码的第三方库 load-json-file
Mais si vous chargez directement le fichier json dans le module ECMAScript
, une erreur sera signalée. L'erreur est la suivante : Tout d'abord, activez le mode ESM
. En fait, le document officiel (http://nodejs.cn /api/esm.html#introduction) :
traite le code JavaScript comme un module CommonJS par défaut. Les auteurs peuvent transmettre l'extension de fichier .mjs
, le champ package.json
"type"
ou --input-type</code > Flag indique à Node.js de traiter le code JavaScript comme un module ECMAScript <a href="https://www.php.cn/course/list/24.html" target="_blank"></a></p>Alors, comment puis-je charger un fichier <code>json
dans le module ECMAScript
? En fait, il y a deux solutions : 🎜🎜Supposons qu'il y ait maintenant un fichier json : test.json
🎜🎜Le contenu du fichier est le suivant : 🎜
import {readFileSync, promises as fs} from 'node:fs'; const {readFile} = fs; const parse = (buffer, {beforeParse, reviver} = {}) => { // Unlike `buffer.toString()` and `fs.readFile(path, 'utf8')`, `TextDecoder`` will remove BOM. // 这里对buffer进行转义,没有用`buffer.toString()`和`fs.readFile(path, 'utf8')`,是因为`new TextDecoder().decode(buffer)`这种方式可以删除字节顺序标记(BOM) // 解码 buffer 并返回字符串 let data = new TextDecoder().decode(buffer); // 在parse解析之前对字符串进行处理 if (typeof beforeParse === 'function') { data = beforeParse(data); } return JSON.parse(data, reviver); }; // 导出异步方法 export async function loadJsonFile(filePath, options) { // 如果未指定编码,则返回原始缓冲区。 const buffer = await readFile(filePath); return parse(buffer, options); } // 导出同步方法 export function loadJsonFileSync(filePath, options) { // 如果未指定编码,则返回原始缓冲区。 const buffer = readFileSync(filePath); return parse(buffer, options); }
index. js
Introduisez test.json
:🎜1 Lisez le fichier json
via fs<.> système de fichiers 🎜rrreee🎜Explication : 🎜🎜<code>await
: Selon Proposition await
ECMAScript de niveau supérieur 🎜, le mot-clé await
peut être utilisé au niveau supérieur du module (en dehors de la fonction asynchrone) ; 🎜🎜import .meta.url
: nodejs
renvoie le chemin absolu du protocole file://
local du module, par exemple : file://home/ user/main.js
, s'il y a un autre fichier test.js
dans le module, alors le chemin de test.js
est nouvelle URL ( 'test.js', import.meta.url)
; 🎜🎜nouvelle URL
: Générer un objet du protocole file:
(pour la plupart des fonctions du module fs
, path ou <code>filename
peut être transmis en tant qu'objet en utilisant le protocole file:
). 🎜2. Implémentez 🎜rrreee🎜 via la méthode createRequire
du module module
intégré de nodejs<.> La méthode est implémentée sur la base de la méthode <code>createRequire
fournie par nodejs
. 🎜🎜
🎜3. La bibliothèque tierce de code source de 24 lignes load-json-file
🎜🎜🎜load-json-file🎜 a été accidentellement découverte par moi sur le site npm. Le code source ne comporte que 24 lignes, comme suit : 🎜rrreee🎜🎜load-json-file source code🎜 Dans l'ensemble, c'est relativement simple, mais il existe également de nombreux points de connaissances qui peuvent être appris en profondeur. 🎜🎜Pour plus de connaissances sur les nœuds, veuillez visiter : 🎜tutoriel Nodejs🎜 ! ! 🎜
createRequire
du module module
intégré de nodejs<.> La méthode est implémentée sur la base de la méthode <code>createRequire
fournie par nodejs
. 🎜🎜
3. La bibliothèque tierce de code source de 24 lignes load-json-file
🎜🎜🎜load-json-file🎜 a été accidentellement découverte par moi sur le site npm. Le code source ne comporte que 24 lignes, comme suit : 🎜rrreee🎜🎜load-json-file source code🎜 Dans l'ensemble, c'est relativement simple, mais il existe également de nombreux points de connaissances qui peuvent être appris en profondeur. 🎜🎜Pour plus de connaissances sur les nœuds, veuillez visiter : 🎜tutoriel Nodejs🎜 ! ! 🎜
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Les principales différences entre Node.js et Tomcat sont : Runtime : Node.js est basé sur le runtime JavaScript, tandis que Tomcat est un conteneur de servlet Java. Modèle d'E/S : Node.js utilise un modèle asynchrone non bloquant, tandis que Tomcat est un modèle de blocage synchrone. Gestion de la concurrence : Node.js gère la concurrence via une boucle d'événements, tandis que Tomcat utilise un pool de threads. Scénarios d'application : Node.js convient aux applications en temps réel, gourmandes en données et à forte concurrence, et Tomcat convient aux applications Web Java traditionnelles.

Node.js est un environnement d'exécution JavaScript côté serveur, tandis que Vue.js est un framework JavaScript côté client permettant de créer des interfaces utilisateur interactives. Node.js est utilisé pour le développement côté serveur, comme le développement d'API de service back-end et le traitement des données, tandis que Vue.js est utilisé pour le développement côté client, comme les applications monopage et les interfaces utilisateur réactives.

Node.js peut être utilisé comme framework backend car il offre des fonctionnalités telles que des performances élevées, l'évolutivité, la prise en charge multiplateforme, un écosystème riche et une facilité de développement.

Oui, Node.js est un langage de développement backend. Il est utilisé pour le développement back-end, notamment la gestion de la logique métier côté serveur, la gestion des connexions à la base de données et la fourniture d'API.

Il existe deux fichiers liés à npm dans le répertoire d'installation de Node.js : npm et npm.cmd. Les différences sont les suivantes : différentes extensions : npm est un fichier exécutable et npm.cmd est un raccourci de fenêtre de commande. Utilisateurs Windows : npm.cmd peut être utilisé à partir de l'invite de commande, npm ne peut être exécuté qu'à partir de la ligne de commande. Compatibilité : npm.cmd est spécifique aux systèmes Windows, npm est disponible multiplateforme. Recommandations d'utilisation : les utilisateurs Windows utilisent npm.cmd, les autres systèmes d'exploitation utilisent npm.

Les variables globales suivantes existent dans Node.js : Objet global : global Module principal : processus, console, nécessiter Variables d'environnement d'exécution : __dirname, __filename, __line, __column Constantes : undefined, null, NaN, Infinity, -Infinity

Les principales différences entre Node.js et Java résident dans la conception et les fonctionnalités : Piloté par les événements ou piloté par les threads : Node.js est piloté par les événements et Java est piloté par les threads. Monothread ou multithread : Node.js utilise une boucle d'événements monothread et Java utilise une architecture multithread. Environnement d'exécution : Node.js s'exécute sur le moteur JavaScript V8, tandis que Java s'exécute sur la JVM. Syntaxe : Node.js utilise la syntaxe JavaScript, tandis que Java utilise la syntaxe Java. Objectif : Node.js convient aux tâches gourmandes en E/S, tandis que Java convient aux applications de grande entreprise.

Étapes de déploiement de serveur pour un projet Node.js : Préparez l'environnement de déploiement : obtenez l'accès au serveur, installez Node.js, configurez un référentiel Git. Créez l'application : utilisez npm run build pour générer du code et des dépendances déployables. Téléchargez le code sur le serveur : via Git ou File Transfer Protocol. Installer les dépendances : connectez-vous en SSH au serveur et installez les dépendances de l'application à l'aide de npm install. Démarrez l'application : utilisez une commande telle que node index.js pour démarrer l'application ou utilisez un gestionnaire de processus tel que pm2. Configurer un proxy inverse (facultatif) : utilisez un proxy inverse tel que Nginx ou Apache pour acheminer le trafic vers votre application
