質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Next.js

Next.jsは、Reactを用いたサーバサイドレンダリングなどを行う軽量なフレームワークです。Zeit社が開発しており、nextコマンドでプロジェクトを作成することにより、開発環境整備が整った環境が即時に作成できます。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

0回答

859閲覧

カテゴリ別一覧ページを作りたい

manjukowai

総合スコア0

Next.js

Next.jsは、Reactを用いたサーバサイドレンダリングなどを行う軽量なフレームワークです。Zeit社が開発しており、nextコマンドでプロジェクトを作成することにより、開発環境整備が整った環境が即時に作成できます。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2021/04/01 09:20

編集2021/04/01 09:22

前提・実現したいこと

Next.jsでブログを作成しています。
カテゴリ別で投稿を一覧表示するページを作りたいのですが、動的ルーティングの方法がよくわからず詰まっています。

各投稿はMarkdownで書かれています。
Next.jsのチュートリアルを参照に、全投稿を一覧表示するページの作成は完了しました。

各Markdownのfrontmatterにカテゴリ名を記載し、そのカテゴリ名ごとに一覧ページを作りたいと思っています。

このケースの場合、getStaticPropsをどのように実装すれば良いのでしょうか。

ページ構成は以下のようになっています。

root
├ .next/
├ node_modules/
├ styles/
│ ├ globals.css
│ └ その他各CSS
├ pages/
│ ├ app.js
│ ├ 400.js
│ ├ api.js
│ ├ index.js
│ ├ posts/
│ ├ [id].js //全記事一覧ページ
│ └ category/
│ └ [categories].js //カテゴリ別一覧ページ
├ components/
│ ├ layout.js
│ ├ date.js
│ └ layout.module.css
├ lib/
│ └ post.js
├ public/
│ └ img
│ ├ favicon.ico
│ └ その他画像
├ package-lock.json
├ package.json
└ posts/
└ 各投稿(Markdown)

該当のソースコード

lib/posts.js

Javascript

1 2import fs from 'fs' 3import path from 'path' 4import matter from 'gray-matter' 5 6const postsDirectory = path.join(process.cwd(), 'posts') 7 8~省略~ 9 10export async function getAllPostCategories(id){ 11 const fullPath = path.join(postsDirectory, `${id}.md`) 12 const fileContents = fs.readFileSync(fullPath, 'utf8') 13 const matterResult = matter(fileContents) 14 const categoryNames = matterResult.category 15 return categoryNames.map(categoryName => { 16 const categoryNames = categoryNames 17 return { 18 params: { 19 category: categoryName 20 } 21 } 22 }) 23} 24

pages/posts/category/[category].js

Javascript

1import Layout from '../../../components/layout' 2import { getAllPostCategories } from '../../../lib/posts' 3 4export async function getStaticPaths(){ 5 const paths = getAllPostCategories() 6 return { 7 paths, 8 fallback: false 9 } 10} 11 12export default function Category(){ 13 return <Layout>...</Layout> 14} 15

posts内のMarkdown

Markdown

1--- 2title: '◯◯◯' 3date: '◯◯◯' 4category: 'カテゴリ1' 5--- 6 7本文

エラー

現在は以下のようなエラーが出ています。

Error: Invalid paths value returned from getStaticPaths in /posts/category/[category].
paths must be an array of strings or objects of shape { params: [key: string]: string }

よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問