Asp.net MVC5 angular4未捕获引用错误:部署到IIS后系统未在systemjs.config.js中定义

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Asp.net MVC5 angular4未捕获引用错误:部署到IIS后系统未在systemjs.config.js中定义相关的知识,希望对你有一定的参考价值。

我创建了Asp.Net MVC Angular2应用程序,它在visual studio2017外部主机上运行时工作正常。但是当我发布这个应用程序并通过IIS运行时。我收到一个错误

未捕获的ReferenceError:未定义系统

  1. systemjs.config.js和
  2. _Layout.cshtml System.import('app')。catch(function(err){console.error(err);});

下面是我的Bundle.config类:

public class BundleConfig
{
     public static void RegisterBundles(BundleCollection bundles)
    {
        bundles.Add(new ScriptBundle("~/bundles/jquery").Include(
                    "~/Scripts/jquery-{version}.js"));

        bundles.Add(new ScriptBundle("~/bundles/jqueryval").Include(
                    "~/Scripts/jquery.validate*"));

        bundles.Add(new ScriptBundle("~/bundles/angular").Include(                
                   "~/node_modules/core-js/client/shim.min.js",
                   "~/node_modules/systemjs/dist/system-polyfills.js",                                 
                   "~/node_modules/zone.js/dist/zone.js",
                   "~/node_modules/systemjs/dist/system.src.js",
                   "~/node_modules/systemjs/dist/system.js",
                   "~/systemjs.config.js"
                   ));

        bundles.Add(new ScriptBundle("~/bundles/modernizr").Include(
                    "~/Scripts/modernizr-*"));

        bundles.Add(new ScriptBundle("~/bundles/bootstrap").Include(                      
                  "~/Scripts/bootstrap.min.js",                      
                  "~/Scripts/respond.js"                       
                  ));

        bundles.Add(new StyleBundle("~/Content/css").Include(
                  "~/Content/bootstrap.min.css",
                  "~/Content/font-awesome.min.css",
                  "~/Content/animate.min.css",
                  "~/node_modules/angular2-busy/build/style/busy.css",
                  "~/node_modules/ng2-toastr/bundles/ng2-toastr.min.css",
                   "~/Content/custom.css"                       
                  ));          
    }
}

systemjs.config.js

 (function (global) {
        SystemJS.config({        
        paths: {
            'npm:': 'node_modules/'
        },
        map: {
          'app': 'app',

          '@angular/core': 'npm:@angular/core/bundles/core.umd.js',
          '@angular/common': 'npm:@angular/common/bundles/common.umd.js',
          '@angular/compiler': 'npm:@angular/compiler/bundles/compiler.umd.js',
          '@angular/platform-browser': 'npm:@angular/platform-browser/bundles/platform-browser.umd.js',
          '@angular/platform-browser-dynamic': 'npm:@angular/platform-browser-dynamic/bundles/platform-browser-dynamic.umd.js',
          '@angular/http': 'npm:@angular/http/bundles/http.umd.js',
          '@angular/router': 'npm:@angular/router/bundles/router.umd.js',
          '@angular/forms': 'npm:@angular/forms/bundles/forms.umd.js',
          '@angular/animations': 'npm:@angular/animations/bundles/animations.umd.js',
          '@angular/animations/browser': 'npm:@angular/animations/bundles/animations-browser.umd.js',
          '@angular/platform-browser/animations': 'npm:@angular/platform-browser/bundles/platform-browser-animations.umd.js', 
          'file-saver': 'npm:file-saver/',
          'angular2-busy': 'npm:angular2-busy',

          'ng2-smart-table': 'npm:ng2-smart-table',
          'ng2-completer': 'npm:ng2-completer',
          'ng2-bs3-modal': 'npm:/ng2-bs3-modal',
          'lodash': 'npm:lodash',
          'rxjs': 'npm:rxjs',
          'angular-in-memory-web-api': 'npm:angular-in-memory-web-api/bundles/in-memory-web-api.umd.js',
          'mydatepicker': 'npm:mydatepicker/bundles/mydatepicker.umd.min.js',
          'ng2-toastr': 'npm:ng2-toastr',

          'moment': 'npm:moment',
          'ngx-pipes': 'npm:ngx-pipes/bundles/ngx-pipes.umd.min.js'

        },
        packages: {
                app: { main: 'main.js', defaultExtension: 'js' },
                rxjs: { defaultExtension: 'js' },
                'ng2-bs3-modal': { main: '/bundles/ng2-bs3-modal.js', defaultExtension: 'js' },
                'ng2-smart-table': { main: 'bundles/table.umd.js', defaultExtension: 'js' },
                'ng2-completer': { main: 'ng2-completer.umd.js', defaultExtension: 'js' },
                'lodash': { main: 'lodash.js', defaultExtension: 'js' },
                'file-saver': { format: 'global', main: 'FileSaver.js', defaultExtension: 'js'},
                'angular2-busy': { main: './index.js', defaultExtension: 'js' },
                'moment': { main: 'moment', defaultExtension: 'js' },            
                'ng2-toastr': { main: '/bundles/ng2-toastr.min.js', defaultExtension: 'js' },     
            }
      });
    })(this);
答案

我发现了一个解决方法,我将我的node_modules文件夹从我的项目复制到发布包,看到错误消失了

以上是关于Asp.net MVC5 angular4未捕获引用错误:部署到IIS后系统未在systemjs.config.js中定义的主要内容,如果未能解决你的问题,请参考以下文章

未验证 ASP.NET MVC5 模型

ASP.NET MVC5/IIS Express 无法调试 - 代码未运行

ASP.NET MVC5 Bootstrap 3 模态表单未验证客户端并回发到页面

Asp .net 中的错误:未捕获的 ReferenceError:HTMLButtonElement

数据表未捕获类型错误:无法读取未定义的属性“添加”(asp.net / js)

ASP.NET - 未捕获的 SyntaxError:无法在模块外使用 import 语句