JavaScript の JSON モジュールに関する詳細なチャット

青灯夜游
リリース: 2021-12-28 19:05:02
転載
2020 人が閲覧しました

この記事では、新しい ECMAScript の提案である JSON モジュールについて説明します。JSON モジュールがどのように機能するかを見てみましょう。皆さんのお役に立てれば幸いです。

JavaScript の JSON モジュールに関する詳細なチャット

ECMAScript モジュール システム (import および export キーワード) は、デフォルトでは JavaScript コードのみをインポートできます。

ただし、多くの場合、アプリケーションの構成を JSON ファイルに保存すると便利なので、JSON ファイルを ES モジュールに直接インポートすることもできます。

長い間、commonjs モジュール形式は JSON のインポートをサポートしてきました。

良いニュースは、JSON モジュールと呼ばれる第 3 フェーズの新しい提案で、JSON を ES モジュールにインポートする方法が提案されていることです。ここで、JSON モジュールがどのように機能するかを見てみましょう。

1. config.json のインポート

次の内容を含む config.json ファイルがあると仮定します:

{
  "name": "My Application",
  "version": "v1.2"
}
ログイン後にコピー

config.json を ES モジュールにインポートするにはどうすればよいですか?

たとえば、JSON 構成ファイルからアプリケーションの名前とバージョンを表示する単純な Web アプリケーションを作成します。

config.json を直接インポートしようとすると、Node.js はエラーをスローします。

import http from 'http';
import config from './config.json';
http
  .createServer((req, res) => {
    res.write(`App name: ${config.name}\n`);
    res.write(`App version: ${config.version}`);
    res.end();
  })
  .listen(8080);
ログイン後にコピー

node.js は、アプリケーションを実行しようとするとエラーをスローしますTypeError [ERR_UNKNOWN_FILE_EXTENSION]: 不明なファイル拡張子 ".json"

JavaScript の JSON モジュールに関する詳細なチャット

# #Node.js は、

import ステートメントを使用する場合、デフォルトで JavaScript コードを想定します。しかし、JSON モジュールの提案のおかげで、インポートするデータ型 (JSON) を指定できます。

アプリケーションを修正する前に、まず JSON モジュールの提案に含まれるものを見てみましょう。

2. JSON モジュール提案

JSON モジュール提案の本質は、通常の

import ステートメントを使用して JSON データをインポートできるようにすることです。 ESモジュール。

インポート アサーションを追加することで、JSON コンテンツをインポートできます。

import jsonObject from "./file.json" assert { type: "json" };
ログイン後にコピー

assert {type: "json"} は、モジュールを解析し、 jsonとしてインポートされます。

jsonObject 変数には、file.json の内容を解析した後に作成された通常の JavaScript オブジェクトが含まれています。

JSON モジュールのコンテンツはデフォルトを使用してインポートされます。名前付きインポートは使用できません。

JSON モジュールは動的にインポートすることもできます:

const { default: jsonObject } = await import('./file.json', {
  assert: {
    type: 'json'
  }
});
ログイン後にコピー

JSON モジュールを含むモジュールが動的にインポートされる場合、デフォルトのコンテンツは

default 属性で使用できます。

この場合、インポート アサーションは JSON 型を表します。ただし、CSS モジュールなど、より多くのデータ形式をインポートできるようにする、アサーションをインポートするためのより一般的な提案があります (現在ステージ 3)。

3. JSON モジュールを有効にする

次に、JSON モジュールを Web アプリケーションに統合します:

import http from 'http';
import config from './config.json' assert { type: "json" };
http
  .createServer((req, res) => {
    res.write(`App name: ${config.name}\n`);
    res.write(`App version: ${config.version}`);
    res.end();
  })
  .listen(8080);
ログイン後にコピー

メイン モジュールは、

をインポートします。 config.json ファイルを開き、その値 config.name および config.version にアクセスします。

JavaScript の JSON モジュールに関する詳細なチャット

JSON モジュールは Node.js バージョン

>=17.1 で動作します。--experimental-json-modules# を使用することもできます。 # #flag は実験用 JSON モジュールを有効にします <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:js;toolbar:false;">node --experimental-json-modules index.mjs</pre><div class="contentsignin">ログイン後にコピー</div></div> ブラウザ環境では、JSON モジュールは Chrome 91 以降で使用できます。

4. 概要

デフォルトでは、ES モジュールは JavaScript コードのみをインポートできます。

JSON モジュールの提案により、JSON コンテンツを ES モジュールに直接インポートできます。 import ステートメントの後に import アサーションを使用するだけです。

import jsonContent from "./file.json" assert { type: "json" };
ログイン後にコピー

JSON モジュールは、実験的フラグ

--experimental-json-modules

を使用して Node.js 17.1 以降、および Chrome 91 以降で使用できます。 プログラミング関連の知識について詳しくは、

プログラミング ビデオ

をご覧ください。 !

以上がJavaScript の JSON モジュールに関する詳細なチャットの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:segmentfault.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート