我正在为我的个人网站建立一个博客部分.由于以下错误,我无法打开博客文章:

(Vercel logs)

Error: ENOENT: no such file or directory, open '/var/task/src/content/hello.mdx'
    at Object.openSync (node:fs:601:3)
    at Object.readFileSync (node:fs:469:35)
    at PostPage (/var/task/.next/server/app/posts/[slug]/page.js:381:45)
    at S (/var/task/.next/server/chunks/789.js:6503:13)
    at eb (/var/task/.next/server/chunks/789.js:6618:21)
    at Array.toJSON (/var/task/.next/server/chunks/789.js:6422:20)
    at stringify (<anonymous>)
    at pb (/var/task/.next/server/chunks/789.js:6829:9)
    at mb (/var/task/.next/server/chunks/789.js:6728:29)
    at Timeout._onTimeout (/var/task/.next/server/chunks/789.js:6553:16) {
  errno: -2,
  syscall: 'open',
  code: 'ENOENT',
  path: '/var/task/src/content/hello.mdx'
}

当我访问有关我的投资组合的博客文章时,收到以下错误消息:

应用程序错误:发生服务器端异常(有关详细信息,请参阅服务器日志(log)). 《文摘》:2113801254

项目目录 struct :

my-app/
└── src/
    ├── app/
    │   ├── posts/
    │   │   ├── page.js
    │   │   └── [slug]/
    │   │       └── page.js or PostPage
    │   └── page.js
    ├── layout.js
    ├── page.js
    ├── components
    ├── content/
    │   └── hello.mdx
    └── fonts

错误表明PostPage文件在代码中有错误.我编写了以下代码:

export default function PostPage({ params }) {
  const post = fs.readFileSync(
    path.join(__dirname, "../../../../../src/content/" + params.slug + ".mdx"),
    "utf-8"
  );
  const { data: frontmatter, content } = matter(post);
  const blog = DOMPurify.sanitize(
    marked.parse(content, { mangle: false, headerIds: false })
  );
.....
//returns jsx with markdown content
}

我try 在readFileSync()中更改路径,但在生产中都不起作用.它在本地开发模式下工作.请帮帮忙.

请注意,我是编程和Nextjs或Vercel的初学者.谢谢

推荐答案

您在此处使用了错误的路径->;path.join(__dirname, "../../../../../src/content/" + params.slug + ".mdx"),‘__dirname’是您的根文件夹.try 记录__dirname,或者您应该使用process.cwd()

Javascript相关问答推荐

如何使用JavaScript动态地将CSS应用于ToDo列表?

不渲染具有HTML参数的React元素

React存档iframe点击行为

使用JavaScript重新排序行

判断表格单元格中是否存在文本框

我们如何从一个行动中分派行动

使用GraphQL查询Uniswap的ETH价格

如何从HTML对话框中检索单选项组的值?

用于在路径之间移动图像的查询

在Matter.js中添加从点A到另一个约束的约束

如何在箭头函数中引入or子句?

如何通过Axios在GraphQL查询中发送数组

不协调嵌入图片

为什么我看到的是回复,而不是我的文档?

与在编剧中具有动态价值的定位器交互

是否设置以JavaScript为背景的画布元素?

使用Perl Selify::Remote::Driver执行Java脚本时出错

无法向甜甜圈图表上的ChartJSImage添加可见标签

如何将值从后端传递到前端

验证Java脚本函数中的两个变量