😢

NextJSが最新版なのにCSSが読み込まれない!

2022/04/13に公開

めちゃ初歩的なミステイクなのですが、1日くらい苦戦したのでいつかの誰かのためにと思って書きます。

  • 開発環境
    • next: 12.0.7
    • react: 17.0.2
    • react-responsive-carousel: 3.2.23

自分は最近NextJSを触り始めた者ですが、元々 MaterialUI × styled-components でReactアプリ開発をすることが多かったこともあり、今回も同様な構成にしようとnext.config.jsで色々設定していました。

そして今までは問題なく開発出来ていたのですが、カルーセルを表示させようと react-responsive-carousel を入れたところ、見事に沼りました。

Hoge.tsx
import React from "react";
import Box from "@mui/material/Box";
import "react-responsive-carousel/lib/styles/carousel.min.css"; // 追加
import { Carousel } from "react-responsive-carousel"; // 追加

type CarouselProps = {
  srcList: string[];
};

const CustomCarousel = React.memo(({ srcList }: CarouselProps) => (
  <Carousel
    showThumbs={false}
    showArrows
    showStatus
    autoPlay
    infiniteLoop
    swipeable
    centerMode
    centerSlidePercentage={80}
  >
    <Box mx={1}>
      // 画像1
    </Box>
    <Box mx={1}>
      // 画像2
    </Box>
    <Box mx={1}>
      // 画像3
    </Box>
  </Carousel>
));

export default CustomCarousel;

具体的には上記のようなカルーセルを表示するコンポーネントを記述したのですが(今回導入したモジュールは3行目のようにcssを読み込ませないといけない仕様)、下記 Module parse failed: Unexpected token (1:0) You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. エラーに遭遇しました。

ぬえ、ローダーがなくてcss読み込めない?
NextJSってCSS Modulesをビルトインサポートしてるハズだよなぁ...
てかチュートリアルで普通にCSS Modules使えたよなぁ...
とか言いながら、_app.tsxでimportさせてみたり、NextJSのバージョン変えてみたり、モジュールを再度インストールし直したりしてました。

結論 next.config.js のrulesが書き方が悪かっただけでした。

修正版next.config.js
-   config.module.rules = [
+   config.module.rules.push(
      {
        test: /\.[jt]sx?$/ /* babel */,
        use: {
          loader: "babel-loader",
          options: {
            presets: ["next/babel"],
          },
        },
        exclude: /node_modules/,
      },
      {
        test: /\.(png|j?g|gif|svg)$/ /* データURLの出力 */,
        type: "asset/inline",
        exclude: /node_modules/,
      },
      {
        test: /\.(png|j?g|gif|svg)?$/ /* ファイルの出力 */,
        type: "asset/resource",
        exclude: /node_modules/,
      },
-   ];
+   );

ReactのWebpackを記述する時の癖でついついrulesを配列で記述していたのですが、NextJSの場合デフォルトでいくつか設定してくれているので push するのが正解でした。

今度デフォルトのrulesの中身を解読します...

Discussion