javascript - 具有自定义 express 服务器的 Next.js 重新呈现所有自定义路由

标签 javascript reactjs express next.js

我已经在 server.js 中设置了一个自定义 express 服务器,就像 Next.js 的文档给出了 example of ,但是,每次我导航到那里定义的任何动态路由时,都会重新呈现应用程序,包括包含我的样式的应用程序,导致非常糟糕的无样式内容闪现。有没有办法确保动态路由不会触发重新渲染?

这是我的 server.js 文件:

const express = require("express");
const next = require("next");

const dev = process.env.NODE_ENV !== "production";
const app = next({ dev });
const handle = app.getRequestHandler();

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

        server.get("/press/:slug", (req, res) => {
            const actualPage = "/press";
            const queryParams = { slug: req.params.slug, apiRoute: "press" };
            return app.render(req, res, actualPage, queryParams);
        });

        server.get("/locations/:slug", (req, res) => {
            const actualPage = "/locations/location";
            const queryParams = { slug: req.params.slug, apiRoute: "location" };
            return app.render(req, res, actualPage, queryParams);
        });

        server.get("/insights/:slug", (req, res) => {
            const actualPage = "/insights/insight";
            const queryParams = { slug: req.params.slug, apiRoute: "insight" };
            return app.render(req, res, actualPage, queryParams);
        });

        // server.get("/_preview/:id/:wpnonce", (req, res) => {
        //     const actualPage = "/preview";
        //     const queryParams = { id: req.params.id, wpnonce: req.params.wpnonce };
        //     app.render(req, res, actualPage, queryParams);
        // });

        const robotsOptions = {
            root: __dirname + '/static/',
            headers: {
                'Content-Type': 'text/plain;charset=UTF-8',
            }
        };
        server.get('/robots.txt', (req, res) => (
            res.status(200).sendFile('robots.txt', robotsOptions)
        ));

        const sitemapOptions = {
            root: __dirname + '/static/',
            headers: {
                'Content-Type': 'text/xml;charset=UTF-8',
            }
        };
        server.get('/sitemap.xml', (req, res) => (
            res.status(200).sendFile('sitemap.xml', sitemapOptions)
        ));

        server.get("*", (req, res) => {
            return handle(req, res);
        });

        server.listen(3000, err => {
            if (err) throw err;
            console.log("> Ready on http://localhost:3000");
        });
    })
    .catch(ex => {
        console.error(ex.stack);
        process.exit(1);
    });

最佳答案

你的 href 应该是 as 属性。根据文档重建你的 href 属性 看看 nextjs 文档 https://nextjs.org/docs#with-link

关于javascript - 具有自定义 express 服务器的 Next.js 重新呈现所有自定义路由,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51507460/

相关文章:

javascript - @public JsDoc 标记与 @export 一起使用会导致警告

reactjs - 我可以依赖组件中的 useEffect 顺序吗?

node.js - 命中 Express 端点后在 socket.io 中发出

javascript - NodeJS Express JS - MongoError : failed to connect to server

javascript - 获取点击次数并使用 jquery 调用单个 ajax 调用

javascript - 将 UTC 时间转换为本地时间( Angular )

javascript - 在 Javascript 中,属性如何修改对象

css - 使用 webpack 从节点模块加载 CSS 文件

reactjs - 无法使用导入文件中的类

node.js - 何时在快速 session 中使用 saveUninitialized 和重新保存