导入不会按预期生成System.register

时间:2016-07-23 10:53:22

标签: typescript angular

我是Angular2的新手,我正在学习并且正在练习练习。我正在接受Udemy的课程,并将我的练习与此练习进行比较。

我有我的app.component.ts:

import {Component} from 'angular2/core';
import {ClienteListaComponent} from './components/cliente-lista.component';
import {ClienteDetalleComponent} from './components/cliente-detalle.component';


@Component({
  selector: 'app',
  templateUrl: 'app/views/clientes.html',
})

export class AppComponent{

}

显然这是我在main.ts中定义的引导程序

import {bootstrap}    from 'angular2/platform/browser';
import {AppComponent} from './app.component';

bootstrap(AppComponent);

“app”选择器中的代码工作正常。问题是当我尝试使用“ClienteListaComponent”或“ClienteDetalleComponent”中定义的选择器时。

我认为问题是生成app.component.js .. system.register只有angular2 / core而不是其他导入。

System.register(['angular2/core'], function(exports_1, context_1) {
    "use strict";
    var __moduleName = context_1 && context_1.id;
    var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
        var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
        if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
        else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
        return c > 3 && r && Object.defineProperty(target, key, r), r;
    };
    var __metadata = (this && this.__metadata) || function (k, v) {
        if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
    };
    var core_1;
    var AppComponent;
    return {
        setters:[
            function (core_1_1) {
                core_1 = core_1_1;
            }],
        execute: function() {
            AppComponent = (function () {
                function AppComponent() {
                }
                AppComponent = __decorate([
                    core_1.Component({
                        selector: 'app',
                        templateUrl: 'app/views/clientes.html',
                    }), 
                    __metadata('design:paramtypes', [])
                ], AppComponent);
                return AppComponent;
            }());
            exports_1("AppComponent", AppComponent);
        }
    }
});

..因此我可以使用“ClienteListaComponent”和ClienteDetalleComponent“。

我正在使用angular 2.0.0-beta.14,因为我正在使用这个课程。

我疯了,我希望有人可以帮助我。谢谢......

1 个答案:

答案 0 :(得分:0)

我发现了问题..我的问题是jejeje ..我没有在组件装饰器中加载指令。 我写道:

@Component({
  selector: 'app',
  templateUrl: 'app/views/clientes.html',
})

应该是

@Component({
  selector: 'app',
  templateUrl: 'app/views/clientes.html',
  directives:[
            PeliculasListComponent, 
            PeliculasFooterComponent
  ] 
})