0

0

Next.js 静态生成页面源码缺失问题的完整解决方案

花韻仙語

花韻仙語

发布时间:2026-01-29 20:44:01

|

503人浏览过

|

来源于php中文网

原创

Next.js 静态生成页面源码缺失问题的完整解决方案

next.js 项目中使用 `getstaticprops` 和 `getstaticpaths` 却无法在 html 源码中输出渲染后的内容,导致 seo 失效和无 js 环境下页面空白——根本原因在于 `_app.js` 中错误的客户端条件渲染逻辑阻断了服务端静态 html 的生成。

你遇到的问题非常典型:页面在浏览器中渲染正常,但查看网页源代码(View Page Source)时为空白或仅含占位符

,且禁用 JavaScript 后页面完全不显示。这说明 Next.js 的静态生成(SSG)流程被意外破坏,HTML 并未在构建时完成预渲染,而是退化为纯客户端渲染(CSR)。

? 根本原因:_app.js 中的 typeof window !== "undefined" 条件导致 SSR 失败

在你原始的 _app.js 中,关键问题出在这里:

render() {
  const { Component, pageProps } = this.props;

  return (
    typeof window !== "undefined" && ( // ❌ 错误!服务端渲染时 window 不存在,整个 JSX 返回 false
      <>
        
        
      
    )
  );
}

⚠️ typeof window !== "undefined" 在服务端(Node.js 环境)永远为 false,因此 render() 方法返回 false,Next.js 无法生成任何 HTML 内容——这直接导致:

  • getStaticProps 获取的数据被丢弃;
  • 页面源码中只有空壳
  • SEO 抓取器、搜索引擎爬虫及禁用 JS 的用户看到空白页;
  • 所有静态优化(如预加载、preload 标签)失效。

✅ 正确修复:移除服务端不安全的条件判断

只需删除 typeof window !== "undefined" 包裹,让 _app.js 在服务端和客户端均能正常渲染:

// pages/_app.js(修复后)
import React from "react";
import App from "next/app";
import TagManager from "react-gtm-module";
import NextNProgress from "../components/NextNProgress";
import "bootstrap/dist/css/bootstrap.css";
import "../scss/index.scss";

const tagManagerArgs = {
  gtmId: "########",
};

class MyApp extends App {
  static async getInitialProps({ Component, ctx }) {
    let pageProps = {};

    if (Component.getInitialProps) {
      pageProps = await Component.getInitialProps(ctx);
    }

    return { pageProps };
  }

  componentDidMount() {
    TagManager.initialize(tagManagerArgs);
  }

  render() {
    const { Component, pageProps } = this.props;

    return (
      <>
         {/* 注意:确保该组件支持 SSR,否则需做服务端兼容处理 */}
        
      
    );
  }
}

export default MyApp;
✅ 关键点:NextNProgress 等 UI 组件若包含浏览器专属 API(如 window、document),必须在 useEffect 或 componentDidMount 中初始化,或通过 dynamic(import(), { ssr: false }) 懒加载,避免服务端报错。

? 验证是否修复成功

  1. 执行构建并检查输出

    MagickPen
    MagickPen

    在线AI英语写作助手,像魔术师一样在几秒钟内写出任何东西。

    下载
    next build && next export

    检查 out/ 目录下对应页面(如 out/products/123/index.html)是否存在且包含完整 HTML 结构(含

    、产品描述等真实内容)。

  2. 本地验证源码

    • 启动生产服务:npx serve -s out
    • 访问页面 → 右键「查看网页源代码」→ 应可见完整的、已渲染的 HTML(非空
      )。
    • 禁用 JavaScript 测试

      • Chrome DevTools → Application → Service Workers → ✅ “Disable cache” + 勾选 “Disable JavaScript”
      • 刷新页面 → 页面应仍可正常显示内容(证明 SSG 生效)。
    • ⚠️ 补充注意事项

      • _document.js 不得包含 React Hooks 或状态逻辑:你当前的 _document.js 是合规的(仅负责注入 资源),无需修改;但切勿在此文件中调用 useState、useEffect 或任何客户端专属逻辑。
      • 第三方脚本需延迟加载:如 GTM、Inspectlet 等分析工具,务必仅在 componentDidMount(客户端)初始化,不可在服务端执行。
      • CSS 加载建议:Bootstrap 的 CDN 链接虽可用,但推荐改用 @import 或 CSS-in-JS 方案以更好支持 SSR;若坚持 CDN,请确保 crossOrigin="anonymous" 拼写正确(你原文中 anomynous 是拼写错误,应为 anonymous)。

      ✅ 总结

      问题现象 根本原因 解决方案
      页面源码为空、SEO 失效、禁 JS 白屏 _app.js 中 typeof window 条件导致服务端渲染中断 移除该条件,确保 render() 始终返回有效 JSX;将浏览器专属逻辑移至 componentDidMount

      修复后,你的 getStaticProps 数据将真正注入 HTML 源码,实现开箱即用的 SEO 友好性与渐进增强体验。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

835

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

744

2023.11.06

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

514

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

244

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

298

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5307

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

481

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

1

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

CSS教程
CSS教程

共754课时 | 24.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号