Angular 6 Server Side Errror:找不到模块:错误:无法解析’./dist/server/main.bundle’

前端之家收集整理的这篇文章主要介绍了Angular 6 Server Side Errror:找不到模块:错误:无法解析’./dist/server/main.bundle’前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在开发一个项目,将其更新为Angular 6.更新后,我在尝试运行服务器端渲染构建时遇到此错误
  1. Module not found: Error: Can't resolve './dist/server/main.bundle'

我尝试使用https://angular.io/guide/universal并将我的代码与Angular Universal中的SSR文件相匹配.这对我不起作用.

似乎dist文件夹没有生成/ server文件夹,但正在创建/浏览器.我不确定为什么.

这是我的angular.json文件

  1. {
  2. "$schema": "./node_modules/@angular/cli/lib/config/schema.json","version": 1,"newProjectRoot": "projects","projects": {
  3. "xilo": {
  4. "root": "","sourceRoot": "src","projectType": "application","architect": {
  5. "build": {
  6. "builder": "@angular-devkit/build-angular:browser","options": {
  7. "outputPath": "dist/browser","index": "src/index.html","main": "src/main.ts","tsConfig": "src/tsconfig.app.json","polyfills": "src/polyfills.ts","assets": [
  8. "src/assets","src/favicon.ico"
  9. ],"styles": [
  10. "src/styles.css","node_modules/font-awesome/css/font-awesome.min.css"
  11. ],"scripts": [
  12. "node_modules/moment/min/moment.min.js"
  13. ]
  14. },"configurations": {
  15. "production": {
  16. "optimization": true,"outputHashing": "all","sourceMap": false,"extractCss": true,"namedChunks": false,"aot": true,"extractLicenses": true,"vendorChunk": false,"buildOptimizer": true,"fileReplacements": [
  17. {
  18. "replace": "src/environments/environment.ts","with": "src/environments/environment.prod.ts"
  19. }
  20. ]
  21. }
  22. }
  23. },"serve": {
  24. "builder": "@angular-devkit/build-angular:dev-server","options": {
  25. "browserTarget": "xilo:build"
  26. },"configurations": {
  27. "production": {
  28. "browserTarget": "xilo:build:production"
  29. }
  30. }
  31. },"extract-i18n": {
  32. "builder": "@angular-devkit/build-angular:extract-i18n","options": {
  33. "browserTarget": "xilo:build"
  34. }
  35. },"test": {
  36. "builder": "@angular-devkit/build-angular:karma","options": {
  37. "main": "src/test.ts","karmaConfig": "./karma.conf.js","tsConfig": "src/tsconfig.spec.json","scripts": [
  38. "node_modules/moment/min/moment.min.js"
  39. ],"src/favicon.ico"
  40. ]
  41. }
  42. },"lint": {
  43. "builder": "@angular-devkit/build-angular:tslint","options": {
  44. "tsConfig": [
  45. "src/tsconfig.app.json","src/tsconfig.spec.json"
  46. ],"exclude": [
  47. "**/node_modules/**"
  48. ]
  49. }
  50. },"server": {
  51. "builder": "@angular-devkit/build-angular:server","options": {
  52. "outputPath": "dist/server","main": "main.server.ts","tsConfig": "tsconfig.server.json"
  53. }
  54. }
  55. }
  56. },"xilo-e2e": {
  57. "root": "","sourceRoot": "e2e","architect": {
  58. "e2e": {
  59. "builder": "@angular-devkit/build-angular:protractor","options": {
  60. "protractorConfig": "./protractor.conf.js","devServerTarget": "xilo:serve"
  61. }
  62. },"options": {
  63. "tsConfig": [
  64. "e2e/tsconfig.e2e.json"
  65. ],"exclude": [
  66. "**/node_modules/**"
  67. ]
  68. }
  69. }
  70. }
  71. }
  72. },"defaultProject": "xilo","schematics": {
  73. "@schematics/angular:class": {
  74. "spec": false
  75. },"@schematics/angular:component": {
  76. "spec": false,"inlineStyle": true,"inlineTemplate": true,"prefix": "app","styleext": "css"
  77. },"@schematics/angular:directive": {
  78. "spec": false,"prefix": "app"
  79. },"@schematics/angular:guard": {
  80. "spec": false
  81. },"@schematics/angular:module": {
  82. "spec": false
  83. },"@schematics/angular:pipe": {
  84. "spec": false
  85. },"@schematics/angular:service": {
  86. "spec": false
  87. }
  88. }
  89. }

server.ts

  1. // These are important and needed before anything else
  2. import 'zone.js/dist/zone-node';
  3. import 'reflect-Metadata';
  4.  
  5. import { enableProdMode } from '@angular/core';
  6.  
  7. import * as express from 'express';
  8. import { join } from 'path';
  9.  
  10. // Faster server renders w/ Prod mode (dev mode never needed)
  11. enableProdMode();
  12.  
  13. // Express server
  14. const app = express();
  15.  
  16. const PORT = process.env.PORT || 4000;
  17. const DIST_FOLDER = join(process.cwd(),'dist');
  18.  
  19. // * NOTE :: leave this as require() since this file is built Dynamically from webpack
  20. const { AppServerModuleNgFactory,LAZY_MODULE_MAP } = require('./dist/server/main.bundle');
  21.  
  22. // Express Engine
  23. import { ngExpressEngine } from '@nguniversal/express-engine';
  24. // Import module map for lazy loading
  25. import { provideModuleMap } from '@nguniversal/module-map-ngfactory-loader';
  26.  
  27. app.engine('html',ngExpressEngine({
  28. bootstrap: AppServerModuleNgFactory,providers: [
  29. provideModuleMap(LAZY_MODULE_MAP)
  30. ]
  31. }));
  32.  
  33. app.set('view engine','html');
  34. app.set('views',join(DIST_FOLDER,'browser'));
  35.  
  36. // TODO: implement data requests securely
  37. app.get('/api/*',(req,res) => {
  38. res.status(404).send('data requests are not supported');
  39. });
  40.  
  41. // Server static files from /browser
  42. app.get('*.*',express.static(join(DIST_FOLDER,'browser')));
  43.  
  44. // All regular routes use the Universal engine
  45. app.get('*',res) => {
  46. res.render('index',{ req });
  47. });
  48.  
  49. // Start up the Node server
  50. app.listen(PORT,() => {
  51. console.log(`Node server listening on http://localhost:${PORT}`);
  52. });

一切都完全按照Angular Universal方向设置.

任何人都知道为什么我的构建脚本不会生成/ server文件夹?

  1. "build:ssr": "npm run build:client-and-server-bundles && npm run webpack:server"

的package.json

  1. {
  2. "name": "XXX","version": "XXX","license": "MIT","repository": {
  3. "type": "git","url": "XXXXX"
  4. },"engines": {
  5. "node": "10.7.0","npm": "6.1.0"
  6. },"scripts": {
  7. "ng": "ng","start": "node dist/server","build": "ng build","build:client-and-server-bundles": "ng build --prod && ng build --prod --project xilo --output-hashing=all","build:prerender": "npm run build:client-and-server-bundles && npm run webpack:server && npm run generate:prerender","build:ssr": "npm run build:client-and-server-bundles && npm run webpack:server","deploy": "git push origin master && git push heroku master","generate:prerender": "cd dist && node prerender","postinstall": "npm run build:ssr","webpack:server": "webpack --config webpack.server.config.js --progress --colors","serve:prerender": "cd dist/browser && http-server","serve:ssr": "node dist/server"
  8. },"private": true,"dependencies": {
  9. "@angular/animations": "6.1.0","@angular/common": "6.1.0","@angular/compiler": "6.1.0","@angular/compiler-cli": "6.1.0","@angular/core": "^6.1.0","@angular/forms": "6.1.0","@angular/http": "6.1.0","@angular/language-service": "6.1.0","@angular/platform-browser": "6.1.0","@angular/platform-browser-dynamic": "6.1.0","@angular/platform-server": "6.1.0","@angular/router": "6.1.0","@nguniversal/express-engine": "^5.0.0-beta.5","@nguniversal/module-map-ngfactory-loader": "^5.0.0-beta.5","@nicky-lenaers/ngx-scroll-to": "^0.5.0","@types/moment": "^2.13.0","@types/node": "^8.10.21","angular-file": "^0.4.1","angular2-moment": "^1.9.0","classlist.js": "^1.1.20150312","core-js": "^2.5.7","cpy-cli": "^1.0.1","express": "^4.16.3","font-awesome": "^4.7.0","http-server": "^0.10.0","moment": "^2.22.2","ng-circle-progress": "^0.9.9","ng-hotjar": "0.0.13","ng-intercom": "^1.0.0-beta.5-2","ng2-google-charts": "^3.4.0","ng4-geoautocomplete": "^0.1.0","ngx-filter-pipe": "^1.0.2","ngx-loading": "^1.0.14","ngx-pagination": "^3.0.3","reflect-Metadata": "^0.1.10","rxjs": "^6.2.2","rxjs-compat": "^6.2.2","ts-loader": "^4.4.2","typescript": "2.9.2","web-animations-js": "^2.3.1","zone.js": "^0.8.20"
  10. },"devDependencies": {
  11. "@angular-devkit/build-angular": "~0.6.8","@angular/cli": "^6.0.8","webpack-cli": "^3.1.0"
  12. }
  13. }
  1. npm cache clear --force
  2. rm -rf node_modules
  3. npm install

并祈祷.

猜你在找的Angularjs相关文章