ホームページ > ウェブフロントエンド > jsチュートリアル > JS を使用して一般的なモジュールを作成する方法を段階的に説明します (詳細なコードの説明)。

JS を使用して一般的なモジュールを作成する方法を段階的に説明します (詳細なコードの説明)。

奋力向前
リリース: 2021-08-26 14:05:23
転載
2177 人が閲覧しました

前回の記事「JavaScriptにおけるタイムスタンプの操作方法を簡単に分析してみた(コード付き)」では、jsにおけるタイムスタンプの操作方法について学びました。次の記事では、JS を使用して一般的なモジュールを作成する方法を説明します。一緒にその方法を見てみましょう。

JS を使用して一般的なモジュールを作成する方法を段階的に説明します (詳細なコードの説明)。

モジュール性の問題は最初から存在しませんでした。WWW が最初に登場したとき、htmlJavaScriptCSS (JSCSS は後に Netscape でブラウザに導入されました) は非常に単純な存在であり、Modular を必要としません。

モジュール化の需要はスケールの産物です。Web ページ Web アプリケーション に進化すると、ブラウザによって処理されるロジックはますます複雑になり、表示スタイルやアニメーションはますます増えており、エンジニアリングに対する要求はますます高くなっています。そこでモジュール化の必要性が生まれました。モジュール化の重要性:

  • コンポーネントの再利用により、開発コストと保守コストが削減されます

  • コンポーネントは個別に開発され、分業と協力が促進されます

  • モジュール性は標準に従っており、依存関係の自動管理、コードの最適化、展開を容易にします

JavaScript は長い間、単純なスクリプトと考えられてきました。言語、実際、状況はずっと前に変わっています。 ECMA-262 (ES6) 文書の最新バージョンでは、JavaScript が一般的なプログラミング言語であることが強調されています。スクリプト言語ではなく。 shell などのスクリプト言語は、複雑な機能を実行するために使用されるのではなく、一部の自動制御を実行するためにのみ使用され、モジュール化は必要ありません。複雑なシステムを構築するために使用される汎用プログラミング言語 (Java など) には、通常、モジュール実装があります。

ES6 より前、JS 言語はモジュール式ではありませんでした。JS をブラウザ内で実行するだけでなく、コードも管理できるようにする方法より効果的に? 、 そこで CommonJS が誕生しました。

CommonJS
    この仕様では 3 つのグローバル変数が定義されています。
  • require,exports,module
    ログイン後にコピー

    require
  • は、 module
  • exports
  • 外部公開モジュールのインターフェイスは任意のタイプにできます
  • module
  • はモジュールそのものです オブジェクト

require で導入されると、取得されるのはこのモジュールによって公開されるインターフェイス (

exports

) Node.js は、

Node.js

内部サポートとは異なり、ブラウザ側で CommonJS 仕様: <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">var foo = require(&quot;foo&quot;); var out = foo.sayName(); module.exports = out;</pre><div class="contentsignin">ログイン後にコピー</div></div> を使用します。 CommonJS、モジュール化する方法は CMDAMD の 2 つの方法があり、主な代表は seajs

requirejs

、両方とも定義します。 グローバル関数定義はモジュールの作成に使用されます: <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">//CMD define(function (require, exports, module) { var foo = require(&quot;foo&quot;); var out = foo.sayName(); module.exports = out; }); //AMD define([&quot;foo&quot;], function (foo) { var out = foo.sayName(); return out; });</pre><div class="contentsignin">ログイン後にコピー</div></div> CMDCommonJS のスタイルを完全に保持していることがわかります。 そして、AMD は、モジュール性を実現するために、依存関係の注入と関数の戻りのより簡潔な方法を使用します。 スタイルの違いは別として、この 2 つの最大の違いは依存モジュールをロードする方法です。CMD は遅延ロードであり、依存関係は require の場合にのみロードされます。 また、

AMD

はプリロードであり、モジュールを定義するときにすべての依存関係を事前にロードします。 seajs (CMD) 環境と requirejs (AMD) 環境の両方に導入できるようにモジュールを実装する必要があります。 Node.js(CommonJS) で使用でき、モジュール性のない環境で

script

タグを使用してグローバルにインポートすることもできます。

最初にモジュールを作成します<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">var factory = function () { var moduleName = {}; return moduleName; };</pre><div class="contentsignin">ログイン後にコピー</div></div>もちろん

return

出力は任意の値、オブジェクト、クラスなどにすることができます。最初に満足する Node.js または ES6 の場合、グローバル変数 module

exports

を使用して、<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">var factory = function () { var moduleName = {}; return moduleName; }; if (typeof module !== &quot;undefined&quot; &amp;&amp; typeof exports === &quot;object&quot;) { module.exports = factory; }</pre><div class="contentsignin">ログイン後にコピー</div></div> が ## のどこにあるかを判断できます。 #CMDAMD では、ファクトリ関数を提供し、モジュールを定義するために define を渡す必要があります。上記のグローバル変数がなく、# がある場合##define グローバル変数。AMD または CMD だと思います。factorydefine に直接渡すことができます。

var factory = function () {
  var moduleName = {};
  return moduleName;
};
if (typeof module !== "undefined" && typeof exports === "object") {
  module.exports = factory;
} else if (typeof define === "function" && (define.cmd || define.amd)) {
  define(factory);
}
ログイン後にコピー

注 : CMD は実際にはリターン モジュール インターフェイスもサポートしているため、両方を互換的に使用できます。

次に、script タグのグローバル インポートも行う必要があります。モジュールを window に配置して、モジュールを使用できるようにします。 Node Global オブジェクトはブラウザ内で内部的に使用でき、Node Global オブジェクトは .js

で使用できます。次の判断ができます:

var global = typeof window !== "undefined" ? window : global;
ログイン後にコピー
すぐに実行されるクロージャ関数を使用して、汚染を避けるためにすべてのコードを含めますグローバル空間と global

オブジェクトはクロージャ関数に渡され、最終的には次のようになります:
(function (global) {
  var factory = function () {
    var moduleName = {};
    return moduleName;
  };
  if (typeof module !== "undefined" && typeof exports === "object") {
    module.exports = factory;
  } else if (typeof define === "function" && (define.cmd || define.amd)) {
    define(factory);
  } else {
    global.factory = factory;
  }
})(typeof window !== "undefined" ? window : global);
ログイン後にコピー

注: クロージャの前のセミコロンは穴を埋めるためのものです。前のモジュールの場合、セミコロンが多すぎても問題ありませんが、少ない場合はステートメントが変わる可能性があります。

#その後、喜んで

//Node.js
var myModule = require(&#39;moduleName&#39;)

//Seajs
define(function(require,exports,module){
  var myModule = require(&#39;moduleName&#39;)
})

// Browser global
<script src=&#39;moduleName.js&#39;></script>
ログイン後にコピー

[終了]

#推奨学習:

JavaScript 上級チュートリアル #

以上がJS を使用して一般的なモジュールを作成する方法を段階的に説明します (詳細なコードの説明)。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
js
ソース:chuchur.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
ノード Js + JS 入力 = document.getElementById
から 1970-01-01 08:00:00
0
0
0
js addClassが機能しない
から 1970-01-01 08:00:00
0
0
0
javascript - jsコードをPythonに変換
から 1970-01-01 08:00:00
0
0
0
jsファイルのコードが見つかりません
から 1970-01-01 08:00:00
0
0
0
人気のチュートリアル
詳細>
関連するチュートリアル
人気のおすすめ
最新のコース
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート