Сбой компиляции AOT для углового материала или формата пакета 4.0

1

Когда я импортирую угловой материал (или любые другие модули формата пакета 4.0), компиляция AOT терпит неудачу.

import { NgModule, ModuleWithProviders } from '@angular/core';
import {MdButtonModule, MdCheckboxModule} from '@angular/material';

@NgModule({
  imports:      [ 
                    MdButtonModule, 
                    MdCheckboxModule
                ],
  exports:      [ 
                    MdButtonModule, 
                    MdCheckboxModule
                ]
})

export class NorSharedModule {
  static forRoot(): ModuleWithProviders {
    return {
      ngModule: NorSharedModule
    };
  }
}

Когда я компилирую с AOT, сгенерированные файлы ngfactory для Angular Material создают циклический импорт.

index.ngfactory.ts

/**
 * @fileoverview This file is generated by the Angular template compiler.
 * Do not edit.
 * @suppress {suspiciousCode,uselessCode,missingProperties,missingOverride}
 */
 /* tslint:disable */

import * as i0 from '@angular/core';
import * as i1 from '@angular/material';
import * as i2 from '@angular/common';
import * as i3 from '@angular/platform-browser';
import * as i4 from './index.ngfactory';
import * as i5 from '@angular/forms';
import * as i6 from '@angular/http';
export const MdCoreModuleNgFactory:i0.NgModuleFactory<i1.MdCoreModule> = i0.ɵcmf(i1.MdCoreModule,

Это, конечно, нарушает следующий этап процесса сборки. Накопитель не может связываться.

[8:51:38] LOG ngc started compiling ngfactory
[8:51:50] LOG ngc compiled /ngfactory 
[8:51:50] LOG Rollup started bundling ngfactory
Error: A module cannot import itself
ngfactory/node_modules/@angular/material/typings/index.ngfactory.js (5:0)
3: import * as i2 from '@angular/common';
4: import * as i3 from '@angular/platform-browser';
5: import * as i4 from './index.ngfactory';
   ^
6: import * as i5 from '@angular/forms';
7: import * as i6 from '@angular/http';

Это повторяется в 4.2.0-rc.2 и 4.2.0.

Теги:
angular
angular2-aot

2 ответа

2
Лучший ответ

Это было исправлено здесь.

Вы можете обновить @angular/compiler и @angular/compiler-cli до 4.3.0-beta.0.

Однако вы обнаружите новую проблему...

(function (exports, require, module, __filename, __dirname) { import * as i0 from '@angular/core';
SyntaxError: Unexpected token import

РЕДАКТИРОВАТЬ

Вы можете следовать этому второму вопросу здесь

0

Скорее всего, это ошибка с пакетом Format 4.0, tcickle и ngfactories, и я подал его команде Angular. Существует обходное решение.

После запуска ngc найдите файлы ngfactory для каждой библиотеки, дублируйте файл, переименуйте его с суффиксом.imports.js, а затем в исходный ngfactory импортируйте новый файл. Это приведет к удалению циклического импорта.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню