我想将一个 HTML 页面(组件)用于另一个组件。但是我找不到点击事件。
仪表板组件:-
import { Component, OnInit, AfterViewInit} from '@angular/core';
import { Router } from '@angular/router';
import { ViewChild } from '@angular/core';
import { HttpClientModule } from '@angular/common/http'; // replaces previous Http service
import { Http, Response , RequestOptions , Headers , URLSearchParams } from '@angular/http';
import { FormsModule, ReactiveFormsModule , FormGroup} from '@angular/forms';
import { HttpModule } from '@angular/http';
import 'rxjs/Rx';
import { webserviceurl } from '../../url.constants';
import { AppAsideComponent } from '../../components/app-aside/app-aside.component';
export class DashboardComponent implements AfterViewInit{
constructor(private router:Router,private http:Http) {
}
ngAfterViewInit(): void {
}
save_outage_index(){
console.log('click');
}
}
Run Code Online (Sandbox Code Playgroud)
Dashboard.module.ts :-
import { NgModule } from '@angular/core';
import { ChartsModule } from 'ng2-charts/ng2-charts';
import { BsDropdownModule } from 'ngx-bootstrap/dropdown';
import { DashboardComponent } from './dashboard.component';
// import { AppAsideComponent } from './../../components/app-aside/app-aside.component';
import { DashboardRoutingModule } from './dashboard-routing.module';
import { jqxGridComponent } from 'jqwidgets-scripts/jqwidgets-ts/angular_jqxgrid';
// import { CommonModule } from '@angular/common';
// import { GridModule } from '../../modules/grid.module';
// import { PanelModule } from '../../modules/panel.module';
@NgModule({
imports: [
DashboardRoutingModule,
ChartsModule,
BsDropdownModule,
],
declarations: [ DashboardComponent,jqxGridComponent]
})
export class DashboardModule { }
Run Code Online (Sandbox Code Playgroud)
app-aside.component.html :-
<button type="button" (click)="save_outage_index()" class="btn btn-sm btn-primary" style="background-color: #455D43;" ><i class="fa fa-dot-circle-o"></i> Submit</button>
Run Code Online (Sandbox Code Playgroud)
app-aside.component.ts :-
import { Component } from '@angular/core';
@Component({
selector: 'app-aside',
templateUrl: './app-aside.component.html'
})
export class AppAsideComponent {
constructor() { }
}
Run Code Online (Sandbox Code Playgroud)
我的问题是如何使用app-aside.component.ts到dashboard.component.ts。
我在dashboard.module.ts和dashboard.component.ts 中尝试过这段代码。
import { AppAsideComponent } from './../../components/app-aside/app-aside.component';
Run Code Online (Sandbox Code Playgroud)
并在这样的声明中使用AppAsideComponent,
@NgModule({
imports: [
DashboardRoutingModule,
ChartsModule,
BsDropdownModule,
],
declarations: [ AppAsideComponent,DashboardComponent,jqxGridComponent]
})
Run Code Online (Sandbox Code Playgroud)
但它仍然显示错误co.save_outage_index is not a function,
单击处理程序save_outage_index需要在与模板相同的组件中定义。
所以你需要在app-aside.component.ts文件中添加处理程序
@Component({
selector: 'app-aside',
templateUrl: './app-aside.component.html'
})
export class AppAsideComponent {
constructor() { }
save_outage_index(){
console.log('click');
}
}
Run Code Online (Sandbox Code Playgroud)
现在,如果您想在仪表板中包含 app-aside 组件,则需要将此 html 添加到仪表板组件的 html 中
仪表板.component.html
<app-aside></app-aside>
Run Code Online (Sandbox Code Playgroud)
如果它们在同一个模块中,则没有额外的工作。如果没有,您需要在仪表板模块中导入包含 app-aside 组件的模块
| 归档时间: |
|
| 查看次数: |
23383 次 |
| 最近记录: |