Node.js 控制台上的Angular6通用给定继续错误

Node.js 控制台上的Angular6通用给定继续错误,node.js,angular,angular6,angular-universal,Node.js,Angular,Angular6,Angular Universal,我使用angular 6并实现了服务器端页面呈现的angular universal, 一切正常,但我的控制台中出现了持续错误 ERROR [Error] ERROR [Error] 我将窗口声明为全局变量,但仍然会出现如下错误 未处理的承诺拒绝:window.some\u函数不是 作用 我的server.ts文件 // 我遇到了同样的问题,并开始调试Visual Studio代码中的server.js,我发现:错误消息是由来自TranslateHttpLoader(我使用的是ngx tran

我使用angular 6并实现了服务器端页面呈现的angular universal, 一切正常,但我的控制台中出现了持续错误

ERROR [Error]
ERROR [Error]
我将窗口声明为全局变量,但仍然会出现如下错误

未处理的承诺拒绝:window.some\u函数不是 作用

我的server.ts文件 //


我遇到了同样的问题,并开始调试Visual Studio代码中的server.js,我发现:错误消息是由来自TranslateHttpLoader(我使用的是ngx translate)的http请求引起的,该请求试图加载带有翻译的.json文件。在谷歌搜索之后,我找到了这个可以找到如何启用服务器端翻译加载的地方。之后,错误消息消失。

您的Angular Universal应用程序应该在服务器上呈现。您将无法访问其中的窗口对象。您可能希望将附加到窗口对象的任何内容移动到其他位置。是的,您是对的。isPlatformBrowser(){if(isPlatformBrowser(this.platformId)){return true;}return false;}使用上述条件,我们可以处理DOM对象,您知道如何处理任何第三方模块的核心文件中使用的DOM对象吗?请尝试使用domino:如何调试server.js?有插件或命令吗?我所看到的只是
错误[Error]
,这并没有太大的帮助。@EliezerBerlin嗨,你知道错误是什么吗?我也得到了与error[error]相同的错误。
import 'zone.js/dist/zone-node';
import 'reflect-metadata';

import { enableProdMode } from '@angular/core';

import * as express from 'express';
import { join } from 'path';
// Express Engine
import { ngExpressEngine } from '@nguniversal/express-engine';
// Import module map for lazy loading
import { provideModuleMap } from '@nguniversal/module-map-ngfactory-loader';

// Faster server renders w/ Prod mode (dev mode never needed)
enableProdMode();

// node run port
const port = 6065;

// Express server
const app = express();

const PORT = port || process.env.PORT;
const DIST_FOLDER = join(process.cwd(), 'dist');

const domino = require('domino');
const fs = require('fs');
const MockBrowser = require('mock-browser').mocks.MockBrowser;
const mock = new MockBrowser();

const template = fs
    .readFileSync(join(DIST_FOLDER, 'browser', 'index.html'))
    .toString();
// Make all Domino types available as types in the global env.
Object.assign(global, domino.impl);
(global as any)['KeyboardEvent'] = domino.impl.Event;
const win = domino.createWindow(template);
win.Object = Object;
win.Math = Math;

global['window'] = win;
global['document'] = win.document;
global['navigator'] = mock.getNavigator();
global['branch'] = null;
global['object'] = win.object;
global['HTMLElement'] = win.HTMLElement;
global['DOMTokenList'] = win.DOMTokenList;
global['Node'] = win.Node;
global['Text'] = win.Text;

// * NOTE :: leave this as require() since this file is built Dynamically from webpack
const { AppServerModuleNgFactory, LAZY_MODULE_MAP } = require('./dist/server/main');

app.engine('html', ngExpressEngine({
    bootstrap: AppServerModuleNgFactory,
    providers: [
        provideModuleMap(LAZY_MODULE_MAP)
    ]
}));

app.set('view engine', 'html');
app.set('views', join(DIST_FOLDER, 'browser'));

// TODO: implement data requests securely
app.get('/api/*', (req, res) => {
    res.status(404).send('data requests are not supported');
});

// Server static files from /browser
app.get('*.*', express.static(join(DIST_FOLDER, 'browser')));

// All regular routes use the Universal engine
app.get('*', (req, res) => {
    res.render('index', { req });
});

// Start up the Node server
app.listen(PORT, '0.0.0.0', () => {
    console.log(`Node server listening on http://localhost:${PORT}`);
});