gpt4 book ai didi

javascript - Next.js 在 html 标记中呈现应用程序,以字符串形式出现

转载 作者:行者123 更新时间:2023-12-04 10:32:28 25 4
gpt4 key购买 nike

我需要在第三方 html 标记中构建我的 Next.js 应用程序。

标记如下:

头文件.txt

<html>
<head>
<title>Some title</title>
</head>
<body>
<header>Some header</header>
<div>


页脚.txt

    </div>
<footer>Some footer</footer>
</body>
</html>


这些文件动态生成到一个文件夹中。当我渲染我的 next.js 应用程序时,我需要将它们包装在我的应用程序周围。

我使用名为的包创建了一个工作示例:html-react-parser

我从 _document.js 中的文件中解析标记,我正在寻找一个自定义元素 id,我将用下一个 js 应用程序替换它,如下所示:

const header = fs.readFileSync(path.resolve(ROOT + '/resources', 'header.txt'), 'utf8');
const footer = fs.readFileSync(path.resolve(ROOT + '/resources', 'footer.txt'), 'utf8');
const shell = `
${header}
<main id="react-app"></main>
${footer}
`;


// later in the render method od _document.js:

render() {
return (
<React.Fragment>
{parse(shell, {
replace: domNode => {
if (domNode.attribs && domNode.attribs.id === 'react-app') {
return (
<React.Fragment>
<Main/>
<NextScript/>
</React.Fragment>
)
}
}
})}
</React.Fragment>
)
}


虽然这可行,但我的问题是,这不是 html-react-parser 的目的,因为它将文件的标记转换为 react 组件,并在转换过程中抛出许多关于 react 不能使用的错误使用的 html Prop 的警告.

也许解决方案是使用 dangerouslySetInnerHTML,但在这种情况下我不能注入(inject)和 .

// it fails because it wont treat the components as normal html
// <Main/><NextScript/> are not evaluated


const header = fs.readFileSync(path.resolve(ROOT + '/resources', 'header.txt'), 'utf8');
const footer = fs.readFileSync(path.resolve(ROOT + '/resources', 'footer.txt'), 'utf8');
const shell = `
${header}
<React.Fragment>
<Main/>
<NextScript/>
</React.Fragment>
${footer}
`;

// later in the render method od _document.js:

render(<html dangerouslySetInnerHTML={{__html: shell}}/>)


如果有人有一个想法,我怎么能设法将我的下一个应用程序包装在来自文件的标记周围,请给我一些建议。

最佳答案

你可以通过 custom server 来实现。 ,

const express = require('express')
const next = require('next')

const header = fs.readFileSync(path.resolve(ROOT + '/resources', 'header.txt'), 'utf8');
const footer = fs.readFileSync(path.resolve(ROOT + '/resources', 'footer.txt'), 'utf8');

const port = parseInt(process.env.PORT, 10) || 3000
const dev = process.env.NODE_ENV !== 'production'
const app = next({ dev })
const handle = app.getRequestHandler()

app.prepare().then(() => {
const server = express()

server.all('*', async (req, res) => {
const nextResponse = await handle(req, res);
return mergeHTML(header, footer, nextResponse); // You will need to "merge" cause nextResponse has `head` & `body` as well.
})

server.listen(port, err => {
if (err) throw err
console.log(`> Ready on http://localhost:${port}`)
})
})
mergeHTML应该从你的 header 合并头部&下一个的头& body 。您可以使用 cheerio 来帮助你。

关于javascript - Next.js 在 html 标记中呈现应用程序,以字符串形式出现,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60357068/

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