Figma

2026年最新版 Figmaプラグイン開発入門:環境構築から公開まで

ⓘ本ページはプロモーションが含まれています

お得なお知らせ

スポンサードリンク
デザイン本が読み放題

Figma・UI/UX・配色の深いノウハウを

動画・記事の断片情報より、1冊の体系書籍のほうが圧倒的に速い。Kindle Unlimited対象のデザイン書籍が豊富です。

Kindle Unlimited 30日無料▶ Audible|デザイン発想本を耳で▶

▶ デザイン→エンジニアリングの橋渡しに興味があれば プログラミング / エンジニア転職 もどうぞ。


タイプ別にすぐ選べる

クリエイティブの引き出し、どう増やす?

Figma・UI/UX・配色・タイポグラフィ。"手を動かす"学びと"発想力を磨く"学びは、使うサブスクが違います。

▷ Figma・UI/UX・配色の具体テクニックを体系化したい実務デザイナー

Kindle Unlimited 30日無料|デザイン本読み放題▶

▷ ブランド・発想・ディレクション系のインプットを"耳で"増やしたい人

オーディオブックAudible

※無料期間中の解約で料金発生なし

▶ デザイン→エンジニアリングの橋渡しに興味があれば プログラミング / エンジニア転職 もどうぞ。


スポンサードリンク

はじめに:2026 年の Figma プラグイン開発環境

2026 年 6 月現在、Figma が提供しているプラグイン API は バージョン 1.0.0 に統一されており(公式ドキュメント)、このバージョンを使用することが審査合格の必須条件となっています。この記事では、最新の公式情報に基づき、ローカル環境の構築からプラグインの公開までの全工程を実務で即活用できる形で解説します。


開発準備:アカウント取得とローカル環境のセットアップ

Figma プラグインはローカルでコードを書き、Figma の開発モードにロードしてテストします。このセクションでは、まず Figma アカウントを作成し、プラグイン開発用の「開発モード」を有効化する手順と、続いて推奨される Node.js とエディタ環境の整備方法をご紹介します。

Figma アカウント取得と開発モード有効化

Figma のプラグインはアカウントさえあればすぐに作成できます。開発モードを有効にしないとローカルファイルの読み込みができませんので、最初に必ず設定してください。

  1. 公式サイトfigma.com)で無料アカウントを作成
  2. デスクトップまたはブラウザ版 Figma を起動し、左上メニューの Plugins → Development を開く
  3. 「Enable development mode」をクリックして有効化する

これだけで「New plugin…」からローカルプロジェクトを登録できるようになります。

Node.js とパッケージマネージャのインストール

公式 CLI は Node 環境上で動作します。2026 年 6 月時点で Node.js LTS は v20.11.0Node.js releases) が最新ですので、これをインストールしてください。

インストール後はターミナルで以下を実行し、バージョンが正しく表示されることを確認します。

パッケージマネージャは npm がデフォルトですが、軽量な pnpmnpm i -g pnpm)でも問題なく利用できます。

推奨エディタと拡張機能の設定

VS Code は公式でも推奨されているエディタです。以下の拡張機能をインストールすれば、型補完・コード整形・Lint が自動化されます。

拡張機能 主な役割
Figma Plugin API(公式) figma グローバルオブジェクトの TypeScript 型定義を提供
ESLint 構文エラー・潜在的バグの検出
Prettier – Code formatter コードフォーマットの統一
GitLens(任意) Git 操作の可視化

VS Code 用設定例(.vscode/settings.json):

これらを整えることで、ローカル環境は Figma プラグイン開発に最適化されます。


プロジェクト作成:公式テンプレートと CLI の活用

Figma が提供するテンプレートと Create Figma Plugin CLI(npm パッケージ create-figma-plugin)を組み合わせると、数分でビルド済みの雛形プロジェクトが完成します。以下では、CLI のインストール方法とオプションの正確な使い方をご紹介します。

テンプレートの種類と manifest.json の基本構造

公式テンプレートは大きく EmptyUI+Code に分かれます。どちらも manifest.json が必須ですが、含まれるフィールドが異なります。

  • Empty:ロジックだけの最小構成。UI を持たないプラグイン向け
  • UI+Code:HTML UI と TypeScript ロジックを同梱した構成。対話型プラグインに必須

manifest.json の主要フィールドは以下のとおりです(※公式ドキュメント参照)。

フィールド Empty 例 UI+Code 例
name "MyEmptyPlugin" "MyUIPlugin"
api "1.0.0" "1.0.0"
main "code.ts" "code.ts"
ui 省略 "ui.html"
permissions ["current_page"] ["document", "clipboardRead"]

最小権限の原則に従い、実際に使用する機能だけを列挙してください。

CLI のインストールと雛形生成手順

公式 CLI は npm で配布されており、以下のコマンドでグローバルインストールできます。--template オプションは ui(UI+Code)または code(Empty)を指定します。

生成されたディレクトリ構造は次のようになります。

その後は依存パッケージをインストールし、開発サーバーを起動します。

CLI が自動で tsconfig.json・ESLint 設定も生成するため、手作業での設定ミスが大幅に減ります。


基本実装とデバッグ:Hello World プラグインを作る

最小限のコードで「Hello World」を表示させ、Figma 内でのデバッグフローを体感します。ここでは UI とロジックの分離パターンを示し、DevTools を用いた実践的なデバッグ手順も併せて解説します。

code.tsui.html の最小実装例

以下は UI+Code テンプレートで生成したプロジェクトにそのまま貼り付けられるコードです。figma.showUI(__html__) で UI を呼び出し、ボタン押下時にメッセージを受信して通知するだけのシンプルな実装になります。

src/code.ts

src/ui.html

このコードを保存したら npm run dev でローカルサーバーが起動し、Figma の開発モードから Import plugin from manifest… でプロジェクトをロードできます。

Figma 内での実行と DevTools デバッグ

  1. Plugins → Development → Import plugin from manifest… を選択し manifest.json があるフォルダを指定
  2. プラグインがサイドバーに表示されたら Run ボタンで起動
  3. UI の右上メニュー(⋮)→ Open DevTools で Chrome DevTools を開く

DevTools のコンソールタブでは console.log、ネットワークリクエスト、JavaScript エラーをリアルタイムに確認できます。CORS エラーが出た場合は UI 側の外部スクリプト依存を排除し、ローカルファイルのみで完結させることが推奨されています(公式ガイド参照)。


ビルド・パッケージングから公開までのフロー

開発が完了したらコードを最適化し、.figma-plugin 形式にパッケージングして Figma Community に提出します。以下ではビルド手順、サイズ上限の確認、バージョン管理方法、そして審査プロセスまでを順番に説明します。

ビルド手順とファイルサイズ制限

CLI が提供する npm run build は TypeScript のコンパイル+Vite によるコード圧縮・最適化を行い、dist/ ディレクトリに成果物を出力します。公式ドキュメントによれば、プラグインバンドルの サイズ上限は 4 MB(2026 年時点)ですので、デバッグ用コードや source map は除外してください。

ビルド後は Git タグでバージョンを管理し、manifest.jsonversion フィールドも忘れずに更新します。

Community へのアップロードと審査プロセス

Figma Community の「Publish」ページから .figma-plugin ファイルを提出します。審査では以下が必須項目となります(公式ガイド参照)。

必要項目 内容
API バージョン "api": "1.0.0"
権限設定 最小権限のみを列挙
アクセシビリティ rolearia-label の付与、キーボード操作のサポート

アップロード手順:

  1. Figma アプリ左側メニューから CommunityPublishNew Plugin を選択
  2. プラグイン名・バージョン・カテゴリ・概要を入力
  3. my-plugin.figma-plugin と 1280 × 720 ピクセル以上のスクリーンショットを添付
  4. 「Submit for review」ボタンで審査依頼

通常、2〜3 営業日以内に結果がメールで通知されます。指摘があれば manifest.json やアクセシビリティ情報を修正し、再提出してください。

2026 年版ベストプラクティス(API・権限・アクセシビリティ)

項目 推奨設定例 理由
API バージョン "api": "1.0.0" 公式が唯一サポートするバージョンで、互換性と審査合格を保証
権限 必要最小限 ("current_page", "clipboardRead" 等) ユーザーのプライバシー保護と信頼獲得に直結
アクセシビリティ UI 要素に role="button"aria-label を付与し、Tab キーで操作可能にする Figma のアクセシビリティガイドライン(2026)に準拠

アクセシブルな UI 例(ui.html


トラブルシューティングとよくある失敗例

開発中に遭遇しやすいエラーとその対処法をまとめました。事前にチェックリストとして活用してください。

manifest.json の構文エラー対策

ポイント:JSON はカンマ抜けやクオート忘れに非常に敏感です。
対策:VS Code の JSON Lint 拡張か、npm run lint(ESLint)で事前検証するとミスを防げます。

CORS エラーと型定義の更新

ポイント:プラグイン UI が外部 API を呼び出す際はサンドボックスが同一オリジンポリシーを適用します。
対策

また、型定義は常に最新に保ちます。

デバッグ時の便利なヒント

  • DevTools の Network タブでリクエスト失敗を即座に確認
  • figma.notify('debug') で UI 上に簡易ログ表示(プラグイン実行中でも可視)
  • エラーが出たら Plugins → Development → Reload plugins でキャッシュクリア

まとめ

  • 公式 API バージョンは 1.0.0、Node.js LTS は v20 系(v20.11.0)を使用
  • Create Figma Plugin CLI の正しいオプションは --template ui(UI+Code)または --template code(Empty)
  • プラグインバンドルのサイズ上限は 4 MB、最小権限とアクセシビリティを必ず遵守

本稿で示した手順に従えば、2026 年時点の公式基準に完全適合したプラグインを数時間で作成し、Figma Community へ公開できるようになります。ぜひ実務に取り入れて、生産性と品質の両立を目指してください。


参考リンク

  1. Figma Plugin API – https://www.figma.com/plugin-docs/api/
  2. Node.js LTS リリース情報 – https://nodejs.org/en/about/releases/
  3. Create Figma Plugin CLI (npm) – https://www.npmjs.com/package/create-figma-plugin
  4. プラグインサイズ上限 – Figma Docs (2026年版)

スポンサードリンク

お得なお知らせ

スポンサードリンク
デザイン本が読み放題

Figma・UI/UX・配色の深いノウハウを

動画・記事の断片情報より、1冊の体系書籍のほうが圧倒的に速い。Kindle Unlimited対象のデザイン書籍が豊富です。

Kindle Unlimited 30日無料▶ Audible|デザイン発想本を耳で▶

▶ デザイン→エンジニアリングの橋渡しに興味があれば プログラミング / エンジニア転職 もどうぞ。


タイプ別にすぐ選べる

クリエイティブの引き出し、どう増やす?

Figma・UI/UX・配色・タイポグラフィ。"手を動かす"学びと"発想力を磨く"学びは、使うサブスクが違います。

▷ Figma・UI/UX・配色の具体テクニックを体系化したい実務デザイナー

Kindle Unlimited 30日無料|デザイン本読み放題▶

▷ ブランド・発想・ディレクション系のインプットを"耳で"増やしたい人

オーディオブックAudible

※無料期間中の解約で料金発生なし

▶ デザイン→エンジニアリングの橋渡しに興味があれば プログラミング / エンジニア転職 もどうぞ。


-Figma