AngularUniversalSSR在访问api时出现错误“ErrorEvent未定义”
创始人
2024-10-29 21:01:15
0

这个错误通常是由于Node.js环境中缺少对客户端事件API(例如window和document)的支持而引起的。 在Angular应用程序中使用的大多数常规事件(如click和mouseover)在服务器上不起作用,因此需要手动创建它们的替代品。

以下是解决此问题的代码示例:

在app.server.module.ts中导入以下代码:

import 'zone.js/dist/zone-node';
import { ngExpressEngine } from '@nguniversal/express-engine';
import * as express from 'express';
import { join } from 'path';

import { AppServerModule } from './app/app.server.module';
import { APP_BASE_HREF } from '@angular/common';
import { provideModuleMap } from '@nguniversal/module-map-ngfactory-loader';

export function createApiRequestOptions(req: express.Request) {
  return {
    headers: {
      Cookie: req.header('Cookie')
    }
  };
}

export function serverFactory(): express.Express {
  const server = express();
  const distFolder = join(process.cwd(), 'dist/browser');
  const indexHtml = existsSync(join(distFolder, 'index.html')) ? 'index.html' : 'index';

  const { AppServerModuleNgFactory, LAZY_MODULE_MAP } = require('./dist/server/main');

  server.engine('html', ngExpressEngine({
    bootstrap: AppServerModuleNgFactory,
    providers: [
      provideModuleMap(LAZY_MODULE_MAP),
      { provide: APP_BASE_HREF, useValue: '/' },
      { provide: 'REQUEST', useFactory: (req: any) => ({ ...req, apiRequestOptions: createApiRequestOptions(req) }), deps: [express.Request] },
    ]
  }));

  server.set('view engine', 'html');
  server.set('views', distFolder);

  server.get('/api/*', (req, res) => {
    const http = require('http');
    const url = require('url');
    const options = createApiRequestOptions(req);
    const apiReq = http.request(url.parse(`http://localhost:3000${req.originalUrl}`), options, (apiRes: any) => {
      const headers = apiRes.headers;

      res.writeHead(apiRes.statusCode, { ...headers });
      apiRes.pipe(res);
      apiRes.on('close', () => {
        res.end();
      });
    });

    apiReq.on('error', (e: ErrorEvent) => {
      console.error(e);
    });

    apiReq.end();
  });

  server.get('*.*', express.static(distFolder, {
    maxAge: '1y'
  }));

  server.get('*', (req, res) => {
    res.render(indexHtml, {
      req,
      providers: [
        { provide: 'REQUEST', useValue: req },
      ]
    });
  });

  return server;
}

export const appUrl = 'http://localhost:4000';

在server.ts文件中,将以下代码放在创建服务器的代码之前:

global['Event'] = null;
global['window'] = { location: { href: null }, Evergreen: { isDocumentReplaced: true }};
global['document'] = { cookie: '', createElement: () => ({}) };
global['navigator'] = {};
global['requestAnimationFrame'] = (callback) => setTimeout(callback, 0, Date.now());
global['XMLHttpRequest'] = require('xmlhttprequest').XMLHttpRequest;

这会在Node.js环境中创建所需的全局变量。请注意,这些变量的实际值不重要,只要

相关内容

热门资讯

我来教教你!填大坑小程序辅助器... 我来教教你!填大坑小程序辅助器,朱雀开心罗松怎么开挂(真的有挂辅助插件) 了解更多开挂安装加(136...
透视真的!中至上饶辅助,we ... 您好:中至上饶辅助这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特别...
记者揭秘!欢乐茶馆挂,九九山城... 记者揭秘!欢乐茶馆挂,九九山城万州辅助(有挂教程辅助开挂脚本) 了解更多开挂安装加(13670430...
透视规律!微信小程序蜀山辅助器... 大家好,今天小编来为大家解答微信小程序蜀山辅助器这个问题咨询软件客服可以免费测试直接加微信(1367...
传递经验!上饶中至辅助插件透视... 传递经验!上饶中至辅助插件透视,海盗来了大白辅助(有挂透明挂辅助开挂挂)1、下载安装好上饶中至辅助插...
透视辅助!老友十三辅助,大菠萝... 您好:这款大菠萝免费辅助器游戏是可以开挂的,确实是有挂的,很多玩家在这款大菠萝免费辅助器游戏中打牌都...
2分钟细说!决战十三水有挂脚本... 您好:这款决战十三水有挂脚本吗游戏是可以开挂的,确实是有挂的,很多玩家在这款决战十三水有挂脚本吗游戏...
透视挂!wepoker专用辅助... >>您好:wepoker插件下载确实是有挂的,很多玩家在这款wepoker插件下载游戏中打牌都会发现...
每日必看!爱来辅助器,衢州都莱... 您好:这款衢州都莱辅助软件游戏是可以开挂的,确实是有挂的,很多玩家在这款衢州都莱辅助软件游戏中打牌都...
透视辅助!蜀山四川小程序技巧,... 透视辅助!蜀山四川小程序技巧,wepoker透视脚本网页(辅助挂)详细开挂辅助软件;无需打开直接搜索...