要在Angular 9 SSR中设置global['window'],可以使用domino库来模拟浏览器环境。下面是一个示例解决方法:
npm install domino --save
import 'zone.js/dist/zone-node';
import { ngExpressEngine } from '@nguniversal/express-engine';
import * as express from 'express';
import { join } from 'path';
import { readFileSync } from 'fs';
import { enableProdMode } from '@angular/core';
// 导入domino库
import { Domino } from 'domino';
// 启用Angular的生产模式
enableProdMode();
// 创建一个Express服务器
const app = express();
// 获取index.html文件的内容
const indexHtml = readFileSync(join('path/to/dist/browser', 'index.html'), 'utf-8');
// 创建一个虚拟的全局window对象
const window = new Domino().getWindow();
global['window'] = window;
global['document'] = window.document;
global['CSS'] = null;
// 设置Express服务器的静态文件目录
app.engine('html', ngExpressEngine({
bootstrap: AppServerModule,
}));
app.set('view engine', 'html');
app.set('views', join('path/to/dist/browser'));
app.get('*.*', express.static(join('path/to/dist/browser')));
// 处理所有其他请求
app.get('*', (req, res) => {
res.render('index', { req, providers: [{ provide: APP_BASE_HREF, useValue: req.baseUrl }] });
});
// 启动Express服务器
app.listen(4000, () => {
console.log('Angular Universal server listening on port 4000');
});
请注意,上述代码中的path/to/dist/browser
应该替换为您的Angular应用程序的构建输出目录。
这样,你就可以在Angular 9 SSR中设置global['window']。在组件或服务中,你可以直接使用global['window']来访问window对象的属性和方法。