gpt4 book ai didi

javascript - 在 NextJs 的服务器端代码中访问静态资源?

转载 作者:搜寻专家 更新时间:2023-10-30 21:49:43 27 4
gpt4 key购买 nike

我使用 NextJS 的静态渲染功能来生成我网站的静态版本,因此我想确保在页面的第一次渲染时提供正确渲染所需的所有数据。

我有许多博客文章,我已将它们存储为/static 中的 .md 文件,并希望在页面中访问它们,例如:

import * as fs from "fs";
...

export default class extends React.Component<IProps, any> {

static async getInitialProps (props: IServerProps) {
const post = (await getDb()).posts.find(p => p.id == props.query.id);
const markdown = fs.readFileSync(`/static/posts/${post.markdownFileName}`);
return { post, markdown }
}
...

但是如果尝试运行上面的代码,我会得到以下错误:

未找到此依赖项:* fs

所以我不确定我应该如何在服务器上访问这些静态资源..

最佳答案

不幸的是,Next.js 不允许使用 webpack 加载器来处理服务器上的不同文件类型(尽管它们用于构建客户端包),但可以使用 Babel 插件。可以在这里找到一个这样的 Markdown 内容插件:https://www.npmjs.com/package/babel-plugin-markdown

.babelrc 中配置后:

{
"plugins": ["markdown"]
}

可以使用markdown.require()来拉入.md内容:

const html = markdown.require('./foo.md')

链接中描述了更多选项!

关于javascript - 在 NextJs 的服务器端代码中访问静态资源?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47663699/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com