如何正确将静态页面转变为“已过期页面”?
P粉930448030
P粉930448030 2023-09-11 19:35:30
0
1
430

我有一堆静态的推广页面。然而,如果促销活动已经过期,我需要导航/显示一个过期页面。在NextJS的静态页面中,正确的方法是什么?

尝试1:在getStaticProps中检查是否过期。问题是,重新验证每600秒发生一次。所以这可能发生在凌晨12:28而不是准点的12:00(取决于我何时部署它)。

所以它没有按时显示过期页面。如何解决这个问题?或者实现“正确”的更换页面的方式。

export const getStaticPaths = async () => {
  const pageSlugs = await api.getAllSlugs();

  const paths = pageSlugs.map((slug) => (params: {promo: slug})
  );

  return {
    paths,
    fallback: "blocking"
  };
};

export async function getStaticProps({ preview = false, params, previewData }) {
  const page = await api.getSlug(params.promo, {
    preview,
    enviroment: previewData?.enviroment
  });

  const isExpired = checkIfExpired(page.promoStart, page.promoEnd);

  const expiredPage =
   isExpired
      ? await api.getPage("expired-page", {
          preview,
          enviroment: previewData?.enviroment
        })
      : null;


  return {
    props: {
      page,
      isExpired,
      expiredPage,
    },
    revalidate: 600
  };
}

P粉930448030
P粉930448030

Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!