概要

ブロックは通常、投稿コンテンツにスタイルを適用したいマークアップ(HTML)を挿入します。このガイドでは、ブロックエディタでCSSを使用するいくつかの異なる方法と、スタイルやスタイルシートの扱い方について説明します。

始める前に

このガイドに示されている例を実装するには、基本的なブロックとWordPress開発環境が必要です。クイックスタートガイドまたはブロックチュートリアルを参照してセットアップしてください。

スタイルを追加する方法

以下は、エディタ内または保存時にブロックにスタイルを追加するために使用できるさまざまな方法です。

方法1: インラインスタイル

最初の方法は、スタイルをインラインで追加する方法です。これにより、定義されたスタイルが挿入された要素のプロパティに変換されます。

useBlockProps Reactフックは、ブロックのラッパー要素にプロパティを設定および適用するために使用されます。以下の例はその方法を示しています:

  1. import { registerBlockType } from '@wordpress/blocks';
  2. import { useBlockProps } from '@wordpress/block-editor';
  3. registerBlockType( 'gutenberg-examples/example-02-stylesheets', {
  4. edit() {
  5. const greenBackground = {
  6. backgroundColor: '#090',
  7. color: '#fff',
  8. padding: '20px',
  9. };
  10. const blockProps = useBlockProps( { style: greenBackground } );
  11. return (
  12. <p { ...blockProps }>Hello World (from the editor, in green).</p>
  13. );
  14. },
  15. save() {
  16. const redBackground = {
  17. backgroundColor: '#900',
  18. color: '#fff',
  19. padding: '20px',
  20. };
  21. const blockProps = useBlockProps.save( { style: redBackground } );
  22. return (
  23. <p { ...blockProps }>Hello World (from the frontend, in red).</p>
  24. );
  25. },
  26. } );

方法2: ブロッククラス名

インラインスタイルは、適用するCSSが少量の場合にうまく機能します。上記よりも多くのCSSがある場合は、別のスタイルシートファイルで管理する方が簡単であることがわかるでしょう。

useBlockProps フックは、ブロックのクラス名を自動的に含め、ブロックの名前にwp-block-を接頭辞として付けて各ブロックの名前を生成し、/名前空間セパレーターを単一の-に置き換えます。

例えば、ブロック名: gutenberg-examples/example-02-stylesheets はクラス名: wp-block-gutenberg-examples-example-02-stylesheets になります。少し長くなるかもしれませんが、他のブロックとの競合を避けるためには最適です。

  1. import { registerBlockType } from '@wordpress/blocks';
  2. import { useBlockProps } from '@wordpress/block-editor';
  3. registerBlockType( 'gutenberg-examples/example-02-stylesheets', {
  4. edit() {
  5. const blockProps = useBlockProps();
  6. return (
  7. <p { ...blockProps }>Hello World (from the editor, in green).</p>
  8. );
  9. },
  10. save() {
  11. const blockProps = useBlockProps.save();
  12. return (
  13. <p { ...blockProps }>Hello World (from the frontend, in red).</p>
  14. );
  15. },
  16. } );

依存関係を構築または追加する

blockEditorを依存関係として含めるには、ビルドステップを実行するか、アセットPHPファイルを更新してください。

スクリプトをビルドし、依存関係とビルドバージョンを追跡するために使用されるアセットファイルを更新します。

  1. npm run build

スタイルシートをエンキューする

スクリプトと同様に、block.jsonファイルを使用してブロックのスタイルをエンキューできます。

エディタビューでのみ読み込むCSSファイルにはeditorStyleプロパティを使用し、エディタビューとフロントエンドの両方でブロックが使用されるときに読み込むCSSファイルにはstyleプロパティを使用し、フロントエンドでのみブロックが使用されるときに読み込むCSSファイルにはviewStyleプロパティを使用します。

エディタコンテンツがiframe内にある場合、styleeditorStyleの両方がiframe内で読み込まれることに注意する価値があります。editorStyleはiframeの外でも読み込まれるため、エディタコンテンツやUIにも使用できます。

例えば:

  1. {
  2. "apiVersion": 3,
  3. "name": "gutenberg-examples/example-02-stylesheets",
  4. "title": "Example: Stylesheets",
  5. "icon": "universal-access-alt",
  6. "category": "layout",
  7. "editorScript": "file:./block.js",
  8. "editorStyle": "file:./editor.css",
  9. "style": "file:./style.css"
  10. }

したがって、プラグインディレクトリ内にエディタビューで読み込むためのeditor.cssファイルを作成します:

  1. /* green background */
  2. .wp-block-gutenberg-examples-example-02-stylesheets {
  3. background: #090;
  4. color: white;
  5. padding: 20px;
  6. }

そして、フロントエンドで読み込むためのstyle.cssファイルを作成します:

  1. /* red background */
  2. .wp-block-gutenberg-examples-example-02-stylesheets {
  3. background: #900;
  4. color: white;
  5. padding: 20px;
  6. }

ファイルは、block.jsonで指定されると自動的にエンキューされます。

@wordpress/scriptsを使用している場合は、@wordpress/scriptsがスタイルシートを処理できるように、対応するJavaScriptファイル内でスタイルシートをインポートする必要があります。

例:

edit.jsではimport './editor.scss';を配置します。

index.jsではimport './style.scss';を配置します。

view.jsではimport './view.scss';(インタラクティブブロックテンプレート)を配置します。

注意: 複数のファイルを含める必要がある場合は、他のプラグインやテーマと同様に標準のwp_enqueue_style関数を使用できます。ブロックエディタ用には以下のフックを使用することをお勧めします:

  • enqueue_block_editor_assets – エディタビューでのみ読み込む
  • enqueue_block_assets – フロントエンドとエディタビューの両方で読み込む

結論

このガイドでは、インラインまたは独自のスタイルシートを使用してブロックにスタイルを適用するいくつかの異なる方法を示しました。これらの方法の両方はuseBlockPropsフックを使用しています。追加の詳細については、ブロックラッパーリファレンスドキュメントを参照してください。

完全なstylesheets-79a4c3コードは、block-development-examplesリポジトリで確認できます。