在服务端渲染(SSR)期间,由于服务器没有窗口(window)对象,因此引用window对象将导致此错误。解决方法是将代码中的所有与window对象有关的部分替换为与平台无关的代码。例如,可使用Angular提供的平台服务(platform)来检查当前平台(如浏览器或服务器)并采取相应的操作。以下是一个示例代码:
// 不良示例 if (window.innerWidth < 768) { // 执行响应式布局 }
// 好的示例 import { PLATFORM_ID } from '@angular/core'; import { isPlatformBrowser } from '@angular/common';
// 先将平台服务和平台ID引入代码中
if (isPlatformBrowser(this.platformId) && window.innerWidth < 768) { // 执行响应式布局 }
// 检查当前平台并安全地引用window对象。如果当前平台非浏览器,该if语句将不被执行,避免了错误的出现。
上一篇:Angular11的生产构建问题
下一篇:Angular11的条件判断失败