0. モジュールとは何か歴史的に、JavaScript にはモジュール システムがなかったため、大規模なプログラムを小さな相互依存ファイルに分割し、それらを簡単な方法で組み立てることは不可能でした。他の言語にもこの機能があり、例えばRubyのrequire、Pythonのimport、さらにはCSSにも@importがありますが、JavaScriptにはこの点に関するサポートがないため、大規模で複雑なプロジェクトの開発に大きな障害となっています。 ES6 より前に、コミュニティはいくつかのモジュール読み込みソリューションを開発しましたが、その中で最も重要なのは CommonJS と AMD でした。 ES6 モジュールの設計思想は、モジュールの依存関係や入力変数、出力変数をコンパイル時に決定できるように、可能な限り静的にすることです。 ES6 モジュールはオブジェクトではなく、エクスポート コマンドを通じて出力用に明示的に指定され、インポート コマンドを通じてインポートされるコードです。 モジュール システムによって解決される主な問題は次のとおりです。
1.モジュールの読み込み<script> タグを使用してモジュールをロードする場合は、type="module" を追加する必要があります。 1.1 方法1<スクリプトタイプ="モジュール"> 「./module.js」からモジュールをインポートします。 </スクリプト> 1.2 方法2<script src="./module.js" type="module"></script> 2. 輸出と輸入2.1 モジュールのエクスポートは他のモジュールからインポートしてアクセスできます。例 1: About.js を使用して Base.js 内の Base オブジェクトを呼び出し、ホームページに出力します。 インデックス.html <スクリプトタイプ="モジュール"> 「./js/About.js」からAboutをインポートします。 console.log(バージョン情報); </スクリプト> ベース 定数ベース = { ニックネーム: 'admin', 年齢: 19 } デフォルトのベースをエクスポートします。 について '../js/Base.js' から Base をインポートします。 const src = `ニックネーム:${Base.nick},年齢:${Base.age}.`; デフォルトの src をエクスポートします。 出力:
2.2 輸出されていなくても輸入できる例 2: About.js はエクスポートされず、ホームページにインポートされます。 インデックス.html <スクリプトタイプ="モジュール"> 「./js/About.js」をインポートします。 </スクリプト> について const src = 'Hello World!'; コンソールログ(ソース); 出力:
2.3 インポートされたコードは一度だけ実行されます例 3: About.js を 3 回インポートし、エクスポート結果を確認します。 インデックス.html <スクリプトタイプ="モジュール"> 「./js/About.js」をインポートします。 「./js/About.js」をインポートします。 「./js/About.js」をインポートします。 </スクリプト> について const src = 'Hello World!'; コンソールログ(ソース); 出力: 「こんにちは世界」 3. デフォルトのエクスポートと対応するインポートexport default はデフォルト値をエクスポートするために使用されます。モジュールには 1 つしか設定できません。 エクスポートにエクスポート デフォルトを使用する場合、インポート名は任意の名前にすることができます。 例 4: export default を使用してエクスポートし、インポートに任意の名前を付けます。 インデックス.html <スクリプトタイプ="モジュール"> 「./js/About.js」からbbbをインポートします。 コンソールにログ出力します。 </スクリプト> について const src = 'Hello World!'; デフォルトの src をエクスポートします。 出力:
4. 輸出とそれに伴う輸入export を使用してエクスポートする場合、インポートの名前は任意にすることはできません。 例 5: export を使用してエクスポートします。 インデックス.html <スクリプトタイプ="モジュール"> 「./js/About.js」から{age、nick}をインポートします。 console.log(ニックネーム、年齢); </スクリプト> jsについて 定数年齢 = 18; {age} をエクスポートします。 // 年齢をエクスポートします; × // エクスポート const age = 18; √ エクスポート const nick = 'admin'; 出力:
5. モジュールに関する注意事項1. モジュールでは、トップレベルの this は undefined を指します。 2import には昇格効果があり、モジュール全体の先頭に昇格され、最初に実行されます。 3. インポートが実行された時点では、コードはまだ実行されていません。 4. インポートとエクスポートは、コード ブロック内ではなく、モジュールの最上位レベルでのみ実行できます。 5.import() は条件付きでインポートできます。 6. 複合書き込みメソッドはエクスポートされており、現在のモジュールでは使用できません 複合書き込み、インポートしてからエクスポート: './js/About.js' から About をエクスポートします。 要約するこの記事はこれで終わりです。皆さんのお役に立てれば幸いです。また、123WORDPRESS.COM のその他のコンテンツにも注目していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: Docker でコンテナのポート マッピングを動的に変更する方法
SVN は Subversion の略称で、ブランチ管理システムを使用して効率的に管理するオープンソ...
1つ。 tomcat を使用したリモート展開1.1 発生した問題:プロジェクトでは、サードパーティの...
目次序文-リンクカスタムネットワーク質問する序文前回は、 -Linkパラメータを使用してコンテナ間の...
目次意味構造例カスタムショートカットキー元に戻すとやり直し録音と再生マクロ要約する意味リクエストをオ...
ラムダ式ラムダ式 (クロージャとも呼ばれる) は、Java 8 のリリースを推進した最も重要な新機能...
簡単な説明これは CSS3 のクールな 3D キューブのプリロード効果です。この特殊効果は、シンプル...
目次1. カスタム指示1. グローバルカスタム指示を登録する2. グローバルカスタム指示を使用する3...
CentOS7では、MySQLをインストールすると、MariaDBもデフォルトでインストールされます...
さまざまなソースからデータを集約することで、中央倉庫を作成できます。データ ウェアハウスは、ビジネス...
この記事では、3Dカルーセル効果をjsで実装するための具体的なコードを参考までに共有します。具体的な...
みなさんこんにちは。今日はカルーセルの実装についてお話しします。私が作成したカルーセルの効果は次のと...
問題の説明Windows Server 2012 R2 または Windows Server 201...
ドライバーモジュールに渡すパラメータ名、タイプ、権限を宣言します。 module_param(変数名...
<br />このページはUTF8エンコードを使用しており、ヘッダーとフッターはテンプレー...
この記事では、Ubuntu 18.04 に Redis と phpredis 拡張機能をインストール...