Uncaught ReferenceError: ace is not defined in angular 4

Uncaught ReferenceError: ace is not defined in angular 4

我在使用命令ng serve --prod时出现了如图所示的错误

当我在本地 运行 它 npm start 它 运行 没问题!

当 运行 在生产中它说 'ace not defined' ?

代码-table.component.html

<div class="codeEditor" ace-editor [(text)]="text" [mode]="languageMode" [theme]="editorTheme" [options]="options" [readOnly]="false"
    [autoUpdateContent]="true" [durationBeforeCallback]="1000" (textChanged)="codeChange($event)"></div>

代码-table.component.ts

import { Component, OnInit, ViewChild } from '@angular/core';
// import { AceEditorDirective } from 'ng2-ace';
// import { AceEditorDirective } from 'ng2-ace-editor';
import 'brace/theme/cobalt';
import 'brace/mode/c_cpp';
import 'brace/mode/java';
import 'brace/mode/python';
import 'brace/mode/ruby';
import { CompilerService } from '../compiler.service';
@Component({
  selector: 'app-code-table',
  templateUrl: './code-table.component.html',
  styleUrls: ['./code-table.component.css']
})
export class CodeTableComponent implements OnInit {
  text: string = "";
  loading: boolean = false;
  options: any = { maxLines: 1000, printMargin: false };
  selectedValue: string = '';
  languageMode: string = "c_cpp";
  editorTheme: string = "cobalt";
  checked: boolean = false;
  isChecked: boolean = false;
  isError: boolean = false;
  isSelect: boolean = false;
  code;
  input;
  result: any;
  constructor(private CompilerService: CompilerService) { }

  ngOnInit() { }

  languageChanged() {
    if (this.selectedValue == "Java")
      this.languageMode = "java";
    if (this.selectedValue == "C++" || this.selectedValue == "C")
      this.languageMode = "c_cpp";
    if (this.selectedValue == "Python")
      this.languageMode = "python";
  }

  setInput() {
    this.checked = this.isChecked;
  }

  codeChange(code) {
    this.code = code;
  }

  submitCode() {

    this.result = {};
    this.isError = false;
    this.isSelect = false;
    this.loading = true;

    if (this.selectedValue == '') {
      this.isSelect = true;
      this.loading = false;
    }
    if(this.selectedValue == 'Java' && !this.code.includes("class Main")){
      this.isError = true ;
      this.result.error = "class name should be 'Main' ";
    }
    if (this.selectedValue && this.code){
      let payload = {
        code: JSON.stringify(this.code),
        lang: this.selectedValue,
        inputRadio: this.isChecked,
        input: this.input
      }
      this.CompilerService.compileCode(payload).subscribe((data) => {
        this.result = data.json();
        this.loading = false;
        if (this.result.error) {
          this.isError = true;
        }
        if(this.result.error===""){
          this.result.error="Unexpected Error Occured, Memory limit maybe Exceeded";
        }
      },
    error=>{
      this.loading = false;
      this.result.error="Implementation Error";
      console.log(error);
    });
    }
  }
}

app.module.ts

import { BrowserModule, } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import {FormsModule, ReactiveFormsModule} from '@angular/forms';
import { AceEditorModule } from 'ng2-ace-editor';
import { AppComponent } from './app.component';
import { CodeTableComponent } from './code-table/code-table.component';
import {Http,HttpModule} from '@angular/http';
import { CompilerService } from './compiler.service';
import { LoadingModule } from 'ngx-loading';


@NgModule({
  declarations: [
    AppComponent,
    CodeTableComponent,
  ],
  imports: [
    FormsModule,
    LoadingModule,
    ReactiveFormsModule,
    BrowserModule,
    AceEditorModule,
    HttpModule
  ],
  providers: [CompilerService],
  bootstrap: [AppComponent]
})
export class AppModule { }

解决方案是:

.angular-cli.json

内的脚本数组中添加 ace javascripts
"scripts": [
    "../node_modules/ace-builds/src-min/ace.js",
    "../node_modules/ace-builds/src-min/mode-sql.js",
    "../node_modules/ace-builds/src-min/theme-twilight.js"
]

对于 angular 6,您必须查看 angular.json 文件并确保您有脚本部分加载 ace.js 文件

"scripts": ["node_modules/ace-builds/src-min/ace.js", ...]