首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >角度4延伸基础零部件

角度4延伸基础零部件
EN

Stack Overflow用户
提问于 2018-03-16 20:26:10
回答 1查看 19.8K关注 0票数 18

我有一个基础组件,它由它的孩子扩展,但当我们在Angular中使用angular-cli创建一个新的组件时,它会创建html和css文件,但我不会从基础组件使用这些文件。

有没有办法在没有html和css的情况下创建一个基础组件?

代码语言:javascript
复制
import { Component, OnInit, Input } from '@angular/core';

@Component({
  selector: 'app-base',
  templateUrl: './base.component.html', //I dont need this
  styleUrls: ['./base.component.css'] ////I dont need this
})
export class BaseComponent implements OnInit {

  constructor() {}

  ngOnInit() {}

}


import { Component } from '@angular/core';

import { BaseComponent } from '../base/base.component';

@Component({
  selector: 'app-child',
  templateUrl: './child.component.html',
  styleUrls: ['./child.component.css']
})
export class ChildComponent extends BaseComponent {

  constructor() {
    super();
  }

  ngOnInit() {
  }

}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-03-16 20:54:15

因为基类不需要自己实例化,所以它是抽象类,不需要有@Component装饰器。

如果基类有依赖关系,并且有可能在子类中省略constructor并继承它,基类应该有@Injectable装饰器:

代码语言:javascript
复制
@Injectable()
export abstract class BaseComponent implements OnInit {
  constructor(public dep: Dep) {}

  ngOnInit() {}
}

@Component({
  selector: 'app-child',
  templateUrl: './child.component.html',
  styleUrls: ['./child.component.css']
})
export class ChildComponent extends BaseComponent {
  // dummy constructor can be omitted
/*
  constructor(dep: Dep) {
    super(dep);
  }
*/
}
票数 28
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49320759

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档