繁体   English   中英

Next.js 动态路由 - 添加 SLUG 后页面重新加载 404

[英]Next.js dynamic route - 404 on page reload after added SLUG

我的项目使用 Next.js 和 Node.js。

我们有什么: 页面结构:

页面/产品/PageSomeName.js

页面/产品/PageEnotherName.js

页面/产品/PageName.js

产品文件夹中的页面名称可以不同

路由.js

routes.add("/products/:id", "/products/[id].js");

服务器.js

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

  server.use(
    "./images",
    express.static(path.join(__dirname, "images"), {
      maxAge: dev ? "0" : "365d"
    })
  );

  server.use(bodyParser.json());

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

  const PORT = process.env.PORT || 9001;

  server.listen(PORT, err => {
    if (err) throw err;
    console.log(`> Read on http://${process.env.SITE_URL_FULL}`);
  });
});

链接组件

 <Link href={`/products/${data.link}`} as={`/products/${data.slug}`}/>

数据数组

export const storeProducts = [
  {
    id: 1,
    title: "Title1",
    link: "product_name_some",
    slug: "product-1-slug",
  },
  {
    id: 2,
    title: "Title2",
    link: "product_name_different_some_name",
    slug: "product-2-slug"
  },

当我为链接添加 slug 时出现问题。

在客户端一切正常。 我在浏览器 url 中使用 localhost:3000/product-2-slug。 但是重新加载后,我从 Next.js 获取 404 错误页面

我必须由服务器端在 server.js 中添加什么才能正常服务器重新加载? 也许我需要在routes.js 中更改 Link 组件或 next-route 设置

谢谢!

server.js 中,您应该有如下路由。

server.get("/products/product1", (req, res) => {
    return handle(req, res);
});
server.get("/products/product2", (req, res) => {
    return handle(req, res);
});
server.get("/products/product3", (req, res) => {
    return handle(req, res);
});

处理相同问题的一个好方法是在pages目录和服务器句柄中创建一个通用的products.js ,如下所示。

服务器.js

server.get("/products/:id", (req, res) => {
    return handle(req, res, { id: req.params.id });
});

并在

pages/products.js我们可以创建一个getInitialProps方法

static getInitialProps (context) {
    // parameters reqturned from server are accessible via
    const id = ctx.query.id
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM