htmxは、提供するコアハイパーメディアインフラストラクチャを強化するための拡張機能をサポートしています。拡張機能メカニズムは、新しい機能を追加するためのコアライブラリへの圧力を軽減し、ハイパーメディア制御の一般化という主な目的に集中できるようにします。
htmxの拡張機能を作成することに興味がある場合は、htmx拡張機能の構築を参照してください。
htmxの拡張機能は、2つのカテゴリに分類されます
| 名前 | 説明 |
|---|---|
| head-support | htmxリクエストでheadタグ情報(スタイルなど)をマージするためのサポートを提供します |
| htmx-1-compat | htmx 2のほとんどの動作変更をhtmx 1のデフォルトに戻します。 |
| idiomorph | htmxチームによって作成されたidiomorphモーフィングライブラリに基づくmorphスワップ戦略を提供します。 |
| preload | この拡張機能を使用すると、ユーザーがリクエストする前にHTMLフラグメントをブラウザのキャッシュにロードできるため、追加のページがユーザーにほぼ瞬時にロードされるように見えます。 |
| response-targets | この拡張機能を使用すると、異なるHTTP応答コードを受信したときにスワップされる異なるターゲット要素を指定できます。 |
| sse | HTMLから直接Server Sent Eventsのサポートを提供します。 |
| ws | HTMLから直接Webソケットサーバーとの双方向通信を提供します。 |
| 名前 | 説明 |
|---|---|
| ajax-header | htmxによって作成されたすべてのリクエストにX-Requested-Withヘッダーを追加します |
| alpine-morph | Alpine.jsには軽量なmorphプラグインが搭載されており、この拡張機能を使用すると、htmxでスワップメカニズムとして使用できます。これは、htmxによってスワップされたAlpineコンポーネント全体でAlpineの状態を保持するために必要です。 |
| class-tools | class-tools拡張機能を使用すると、classesまたはdata-classes属性を使用して、要素のオンまたはオフにスワップされるCSSクラスを指定できます。 |
| client-side-templates | この拡張機能は、JSON/XMLリクエストの応答を、DOMにスワップされる前にクライアント側のテンプレートを介してHTMLに変換することをサポートします。 |
| debug | この拡張機能には、console.debug関数を使用するか、DEBUG:プレフィックス付きのconsole.log関数を使用するか、いずれかの方法で、要素上のすべてのhtmxイベントをログに記録します。 |
| disable-element | この拡張機能は、リクエストをトリガーする要素で設定されている場合、htmxリクエスト中に要素を無効にします。この機能は、hx-disabled-elt属性を介してhtmxのコアの一部になっていることに注意してください。 |
| event-header | この拡張機能は、リクエストにTriggering-Eventヘッダーを追加します。ヘッダーの値は、リクエストをトリガーしたイベントのJSONシリアル化されたバージョンです。 |
| include-vals | include-vals拡張機能を使用すると、include-vals属性を使用して、リクエストに値をプログラムで含めることができます。この属性の値は、JavaScriptオブジェクトリテラルのフィールドとして評価される1つ以上の名前/値ペアです。 |
| json-enc-custom | この拡張機能はjson-encと同様に機能しますが、name属性を使用するだけで、JSONオブジェクト、リストの埋め込み、またはインデックスの処理など、非常に複雑な構造を可能にします。 |
| json-enc | この拡張機能は、パラメーターをurl形式ではなくJSON形式でエンコードします。 |
| loading-states | この拡張機能を使用すると、リクエストが進行中の間、要素の無効化、CSSクラスの追加と削除など、ロード状態を簡単に管理できます。 |
| morphdom-swap | morphdomモーフィングライブラリに基づくmorphスワップ戦略を提供します。 |
| multi-swap | この拡張機能を使用すると、HTML応答からマークされた複数の要素をスワップできます。また、各要素に使用するスワップ方法を選択することもできます。 |
| no-cache | この拡張機能は、HTMXにクライアントキャッシュをバイパスして新しいリクエストを作成させます。サーバー側のキャッシュをバイパスするために、hx-no-cacheヘッダーも追加されます。 |
| path-deps | この拡張機能は、intercooler.js依存関係メカニズムに触発された、パスに基づいた要素間の依存関係の表現をサポートします。 |
| path-params | この拡張機能は、リクエストパラメーターを使用してパス変数を設定します。使用されたパラメーターは削除されるため、クエリ文字列または本文で送信されなくなります。 |
| remove-me | 指定された間隔の後に要素を削除できます。 |
| replace-params | この拡張機能は、リクエストパラメーターを使用して既存のパラメーターを置き換えます。指定された値が空の文字列の場合、パラメーターは削除されます。この拡張機能は、ページネーションや検索のように、すべてのパラメーターをリセットするのではなく、少数のパラメーターのみを置き換えたい場合に役立ちます。 |
| restored | hx-boostの使用中に、戻るボタンのイベントが検出されるたびにイベントをトリガーします |
| safe-nonce | safe-nonce拡張機能を使用すると、既知の信頼できるインラインスクリプトを安全に返すことができるようにすることで、アプリケーション/Webサイトのセキュリティを向上させ、XSSの問題を回避するのに役立ちます |
| signalr | SignalRを介した双方向リアルタイム通信を提供します。 |