【GatsbyJS製ブログ】MDXを使えるようにする!あと書き方とか!

PR

GatsbyでWebサイトを作るようなときは無理にマークダウン形式(.md)を使う必要はないかな、と思うのですが、ブログであればマークダウン形式で記事をガシガシ書いていく方がいいと思います。

ただ、マークダウンは結構できることが限定的、というかカスタマイズしにくいんですよね。

そこで、こちらの記事でも紹介しましたが、ブログ立ち上げの段階でMDXの導入を検討してもいいのかな、と思います。

MDXは「マークダウンにJSXの機能を使えるように埋め込んだもの」というイメージですので、Gatsbyに慣れた人にとってはとても扱いやすく、カスタマイズもしやすい形式です。

この記事では、GatsbyでのMDXの導入方法と書き方について説明していきます。

この記事はこんな人にオススメ
  • GatsbyのブログをMD(マークダウン)ではなくMDXで書きたい!
  • MDXって便利そうだけど、実際どう書くの?
目次

GatsbyでMDXを使えるようにする

公式ドキュメントはこちら。基本的に難しいことはないですが、GraphQLの書き方が変わるところが面倒です。

ですので、MDXで書くならできればGatsbyで色々と作る前にやった方がいいと思います。というか、マークダウンより遥かに使いやすいので、早い段階でMDXに移行することをオススメします。

STEP
gatsby-plugin-mdxとgatsby-plugin-feed-mdxをインストール
$ yarn add gatsby-plugin-mdx gatsby-plugin-feed-mdx @mdx-js/mdx@v1 @mdx-js/react@v1

ついでに必要無くなったgatsby-transformer-remarkとgatsby-plugin-feedをアンインストールしておく。

 $ yarn remove gatsby-transformer-remark gatsby-plugin-feed

※ 以前インストールしたコマンドを使って、新たなGatsbyサイトでMDXを使おうとしたらエラー吐かれました。原因は「@mdx-js/mdx@v1 @mdx-js/react@v1」の辺りのバージョンの違いでした。当たり前ですが、公式ドキュメントを確認した方がよいです。

STEP
gatsby-config.jsのgatsby-transformer-remarkをgatsby-plugin-mdxに変えていく
…
    {
      resolve: `gatsby-plugin-mdx`, //←`gatsby-transformer-remark`だった部分を`gatsby-plugin-mdx`に変更
      options: {
        extensions: [`.mdx`, `.md`], //←この一行を加える
        gatsbyRemarkPlugins: [ //←pluginsだった部分をgatsbyRemarkPluginsに変更
          `gatsby-remark-relative-images`,
          {
            resolve: `gatsby-remark-images`,
            options: {
              maxWidth: 630,
            },
          },
          {
            resolve: `gatsby-remark-responsive-iframe`,
            options: {
              wrapperStyle: `margin-bottom: 1.0725rem`,
            },
          },
          `gatsby-remark-autolink-headers`,
          `gatsby-remark-prismjs`,
          `gatsby-remark-copy-linked-files`,
          `gatsby-remark-smartypants`,
        ],
      },
    },
…
   {
      resolve: `gatsby-plugin-feed-mdx`, //←`gatsby-plugin-feed`だった部分を`gatsby-plugin-feed-mdx`に変更
      …
   }

上記の部分を書き換えます。

STEP
GraphQLのクエリを変更していく

ここがちょっと面倒ですね。

GraphQLを使って記事データを取得するファイル(gatsby-node.js、blog-post.js、などなど)のクエリ部分を以下のように書き換えていきます。

  • allMarkdownRemarkallMdx
  • MarkdownRemarkMdx
  • markdownRemarkmdx
  • htmlbody
クマ

エディタの機能で検索しつつ、丁寧に置換していきましょう。

ちなみにMarkdownRemarkを「mdx」と変換してエラーを吐かれまくり、原因究明に結構な時間を費やしてしまいました…丁寧にやっていきましょう。gatsby-starter-blogならgatsby-node.jsに該当箇所があります。

STEP
MDXを展開する部分(blog-post.jsなど)をMDXRendererに書き換える

blog-post.jsなど、マークダウンファイルを読み込む以下の部分を変更します。

…
<section
  dangerouslySetInnerHTML={{ __html: post.html }}
  itemProp="articleBody"
/>
…

この部分ですね。ここを、

import { MDXRenderer } from "gatsby-plugin-mdx"
…

…
<MDXRenderer
  frontmatter={post.frontmatter} //※
  itemProp="articleBody"
>
  {post.body}
</MDXRenderer>
…

こんな感じに書き換えて、MDXRendererをインポートして、MDXを展開できるようにしておきます。

frontmatterについて。
frontmatterは記事のタイトルやディスクリプションなど、記事情報がまとまった重要な部分で、マークダウンやMDXの最初に「—」で囲まれたところのことを言います。MDXファイル内でfrontmatterを読むようなケース(h1タグにfrontmatterのtitleを使いたい!とか)で、※のようにfrontmatterを明示的に読み込むようにしないと、上手く表示できないことがあるようです。

クマ

以上でMDXを使う準備ができました!

BearFruitのマスコットキャラ「クマ」がLINEスタンプになりました!

プログラマーの心に刺さる、「プログラミングあるある」。毎日使いたくなること間違いなし!

MDXの書き方

それでは、MDXの書き方について説明していきます。

クマ

「こんな使い方ができるんだ」程度に見ていただければ、と思います。

外部パーツをインポートしてみる

他のJSファイルのように外部パーツを作ってインポートすることができます。

---
title: テスト投稿
date: "2022-04-03T23:46:37.121Z"
---

import Quote from '../../../src/components/blogparts/quote' // こんな感じでパーツをインポートする。

## テスト投稿です

<Quote /> // JSXと同じ感覚で使用できる。
import React from "react"

const Quote = () =>{
    return(
        <div>
            クマの名言集
            <ul>
                <li>鮭ってよ…生食は危ないんだぜ?</li>
                <li>人間も働いてばかりじゃなくて冬眠しなよ</li>
                <li>白黒ってだけでチヤホヤされやがって…お前もクマだろ?</li>
            </ul>
        </div>
    )
}

export default Quote

するとこんな感じで出力されます。

外部パーツのインポート
クマ

無事に外部パーツをインポートできました!

CSS Modulesを使ってSCSSを適用する

CSS Modulesという機能を使って、MDXにSCSSを適用していきます。

クマ

CSS Modulesの説明についてはこちら。

これも他のGatsbyパーツのようにscssファイルをインポートすればいいだけです。簡単。

---
title: テスト投稿
date: "2022-04-03T23:46:37.121Z"
---

import * as styles from '../../../src/styles/mdxstyle.module.scss'

## テスト投稿です

<div className = {styles.testclass1}>
こんな感じで書きます。
</div>
.testclass1{
    font-size: 2rem;
}

これでMDXにCSS Modulesを使ってSCSSを適用することができます。

CSS Modulesの適用

gatsby-remark-text-decorationを使ってみる

Gatsbyにはマークダウンを簡単に装飾するためのプラグインgatsby-remark-text-decorationが用意されています。

MDXでも使えるので、是非使ってみてください!

公式ドキュメントはこちら

クマ

環境構築については、いつもの通りですね。npmかyarnでインストールして、gatsby-config.jsに書き加えます。

まずはnpmかyarnでインストール。

$ npm install gatsby-remark-text-decoration
または
$ yarn add gatsby-remark-text-decoration

gatsby-config.jsに以下の記述を追加。

マークダウンを使っている場合、

plugins: [
  {
    …
    resolve: 'gatsby-transformer-remark', //ここのoptionsのpluginsに、
    options: {
      plugins: [
        …
        //ここから、
        {
          resolve: 'gatsby-remark-text-decoration',
          options: {
          }
        },
        //ここまでを追加
        …
      ]
    }
  }
]

こんな感じ。MDXを使っている場合は、

plugins: [
    …
    {
      resolve: `gatsby-plugin-mdx`, //ここのoptionsのgatsbyRemarkPluginsに、
      options: {
        extensions: [`.mdx`, `.md`],
        gatsbyRemarkPlugins: [
          …
          //ここから
          {
            resolve: 'gatsby-remark-text-decoration',
            options: {
            }
          },
          //ここまでを追加
          …
        ],
      },
    },
    …
]
クマ

これでgatsby-remark-text-decorationを使えるようになりました。

例えばMDX内で以下のように書けば、簡単にテキストを装飾することができます。

{c-blue}青です。{/}

{um-red}赤色マーカーの下線{/}です

{um-#FFB6B7}ちょっとカスタムした赤色マーカーの下線{/}です

{class-testclass2}クラス名指定のテストです。{/}
gatsby-remark-text-decorationを使う
クマ

簡単にデコレーションできます。公式ドキュメントを読んで、色々な書き方を調べてみてください。

クラス指定については、CSS Modulesを使うのがいいのか、こちらのクラス指定の方がいいのか、迷いますね。こちらのクラス指定の方が簡単なのですが増えすぎると「クラス名バッティング問題」が生じるので、よく使うものに限定してこちらのクラス指定をしてもいいかもしれません。

まとめ

GatsbyでMDXを使う方法をまとめてみました。

MDXは慣れると便利なのですが、選択肢が多すぎるので(例えばクラス指定の方法とか)自分のブログスタイルと相談しながら、試行錯誤をしていかないといけないと思います。

クマ

色々試してみてくださいね!

Gatsbyを学習している方への私からのオススメ!

私が読んでよかったな、と思うGatsbyの学習をするのにオススメの本を紹介しておきます。

画も多くてとても読みやすく、ステップバイステップでGatsbyJSのサイトを作ることができます!

また、Gatsbyを学習する上で、Reactを同時に学習することもオススメします。

こちらも、まず構成や見た目がとても読みやすい本です。加えてReactに対しての専門的な知識を丁寧に学ぶことができます。ここでReactに対する基礎知識をしっかりしておくと、Gatsbyに対する見方が変わって、Webページをサクサク作ることができるようになります!

あと、色々と調べたのですが、Reactの学習ならUdemyもオススメです。必要な知識を1動画単位で購入できるので、学習に無駄がないです。Reactってあんまり学習できるプログラミングスクールみたいなのがないんですよね…。「React」と検索するだけで大量に動画がでてきます!

あなたへオススメ!
よかったらシェアしてね!
  • URLをコピーしました!
  • URLをコピーしました!
目次