类型错误:无法读取未定义的 NextJS 的属性“标题”

Kot*_*ren 5 javascript next.js

我一直在尝试构建这个博客应用程序,之前很好,在开发环境中也很好。但是,当我尝试构建它进行生产时,它就陷入了这个错误。

预呈现页面“/blogs/[slug]”时发生错误。阅读更多: https: //nextjs.org/docs/messages/prerender-error TypeError:无法读取未定义的属性“标题”

我很困惑,因为这个应用程序之前已经构建过,没有任何问题。这就是罪魁祸首:

import Head from "next/head";
import "bootstrap/dist/css/bootstrap.min.css";
import ReactMarkdown from "react-markdown";
import moment from "moment";

const Post = ({ posts }) => {
  return (
    <>
      <Head>
        <title>{posts && posts.title}</title>
        <meta
          name="viewport"
          content="width=device-width, initial-scale=1.0"
        ></meta>
      </Head>
      <div className="container" style={{ marginTop: "3.85rem" }}>
        <div className="row">
          <h1>{posts.title}</h1>
        </div>
        <div className="row d-flex justify-content-end">
          <p style={{ textAlign: "right" }}>
            {moment(posts.dateTime).format("dddd, Do MMMM YYYY, hh:mm:ss a")}
          </p>
        </div>
        <br />
        <div className="row d-flex justify-content-center">
          <img
            className="postThumbNail"
            src={posts.thumbnail.url}
            alt={posts.thumbnail.url}
          />
        </div>
        <br />
        <ReactMarkdown>{posts.body}</ReactMarkdown>
      </div>
    </>
  );
};

export async function getStaticProps({ params: { slug } }) {
  const res = await fetch(
    `https://someapi.com/blogs?slug=${slug}`
  );
  const blogPost = await res.json();

  return {
    props: {
      posts: blogPost[0],
    },
    revalidate: 600,
  };
}

export async function getStaticPaths() {
  // Get Post From Strapi
  const res = await fetch(
    "https://someapi.com/blogs"
  );
  const post = await res.json();
  //  Retrun Enrich Content
  return {
    paths: post.map((posts) => ({
      params: { slug: String(posts.slug) },
    })),
    fallback: true,
  };
}

export default Post;
Run Code Online (Sandbox Code Playgroud)

Che*_*del 3

解决方案 1 您需要首先使用可选链接检查属性是否存在:

  <h1>{posts?.title}</h1>
Run Code Online (Sandbox Code Playgroud)

解决方案 2return null或在数据加载之前 对象不为空

if(!posts) return null

return <div> ...Code </div>
Run Code Online (Sandbox Code Playgroud)