業界トップクラスの求人数を誇る転職エージェントPR

リクルートグループのコネクションを活かした非公開求人も充実、他にはない好条件の求人と出会える

1
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

【JavaScript】モジュールシステム、ECMAScriptモジュールについて

Posted at

モジュール化

コードを分割し、再利用可能な単位にする仕組み のこと。
これにより、コードの管理がしやすくなり、再利用性や保守性が向上する。

メリット

** コードの管理・再利用がしやすくなる **
具体的には次のようなメリットがある

  • 名前空間の衝突を防げる
    • 同じ名前の変数・関数が上書きされるのを防ぐ
  • コードの再利用がしやすい
    • 便利な変数や関数を複数箇所にコピペする必要がなくなる
  • コードが分割できて管理しやすい
    • 機能ごとにファイルを分けられるので、整理しやすく修正しやすい
      • 例)計算する機能だけをmath.jsにわける

主なモジュールシステム

ECMAScriptモジュール(ESM)

読み:エクマスクリプト

  • import / export を使う
  • ブラウザ & Node.js で使える(標準仕様)
  • 非同期ロードが可能(ブラウザ環境)
  • 拡張子は .js / .mjs

<使い方>

// utils.js(モジュール化されたファイル)
export function greet(name) {
  return `Hello, ${name}!`;
}

// main.js(モジュールを使うファイル)
import { greet } from "./utils.js";
console.log(greet("Alice")); // Hello, Alice!

CommonJS(CJS)

  • require / module.exports を使う
  • Node.js のデフォルトのモジュールシステム
  • 同期的な読み込み(ブラウザでは使えない)

<使い方>

// utils.js
module.exports.greet = function(name) {
  return `Hello, ${name}!`;
};

// main.js
const { greet } = require("./utils");
console.log(greet("Alice")); // Hello, Alice!

その他

AMD(Asynchronous Module Definition)、UMD(Universal Module Definition)

参考

1
1
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up

Qiita Conference 2025 will be held!: 4/23(wed) - 4/25(Fri)

Qiita Conference is the largest tech conference in Qiita!

Keynote Speaker

ymrl、Masanobu Naruse, Takeshi Kano, Junichi Ito, uhyo, Hiroshi Tokumaru, MinoDriven, Minorun, Hiroyuki Sakuraba, tenntenn, drken, konifar

View event details
1
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?