【问题标题】:Ionic 4 using components on multiple pagesIonic 4 在多个页面上使用组件
【发布时间】:2019-04-04 15:59:43
【问题描述】:

从一个干净的 ionic 4 项目开始(使用ionic start --type=angular 和空白模板),我正在尝试创建一个可以在多个页面上使用的自定义角度组件。

但是,如果我使用 ionic generate component 并尝试通过插入 <app-test></app-test> 在 homepage.html 中使用生成的组件 test,我会收到错误:

core.js:1673 ERROR Error: Uncaught (in promise): Error: Template parse errors:

'app-test' 不是已知元素: 1. 如果“app-test”是一个 Angular 组件,那么验证它是这个模块的一部分。 2. 如果“app-test”是一个 Web 组件,则将“CUSTOM_ELEMENTS_SCHEMA”添加到该组件的“@NgModule.schemas”以禁止显示此消息。 ("="_blank" rel="noopener" href="https://ionicframework.com/docs">文档将是您的指南。

ERROR 错误:未捕获(承诺):错误:模板解析错误: 'app-test' 不是已知元素: 1. 如果“app-test”是一个 Angular 组件,那么验证它是这个模块的一部分。 2. 如果“app-test”是一个 Web 组件,则将“CUSTOM_ELEMENTS_SCHEMA”添加到该组件的“@NgModule.schemas”以禁止显示此消息。 ("="_blank" rel="noopener" href="https://ionicframework.com/docs">文档将是您的指南。

这是我的文件的样子:app.module.ts

import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { RouteReuseStrategy } from '@angular/router';

import { IonicModule, IonicRouteStrategy } from '@ionic/angular';
import { SplashScreen } from '@ionic-native/splash-screen/ngx';
import { StatusBar } from '@ionic-native/status-bar/ngx';

import { AppComponent } from './app.component';
import { AppRoutingModule } from './app-routing.module';
import { TestComponent } from './test/test.component';

@NgModule({
  declarations: [AppComponent, TestComponent],
  entryComponents: [],
  imports: [BrowserModule, IonicModule.forRoot(), AppRoutingModule],
  providers: [
    StatusBar,
    SplashScreen,
    { provide: RouteReuseStrategy, useClass: IonicRouteStrategy }
  ],
  bootstrap: [AppComponent]
})
export class AppModule {}

app-routing.module.ts

import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';

const routes: Routes = [
  { path: '', redirectTo: 'home', pathMatch: 'full' },
  { path: 'home', loadChildren: './home/home.module#HomePageModule' },
];

@NgModule({
  imports: [RouterModule.forRoot(routes)],
  exports: [RouterModule]
})
export class AppRoutingModule { }

test.component.ts

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

@Component({
  selector: 'app-test',
  templateUrl: './test.component.html',
  styleUrls: ['./test.component.scss']
})
export class TestComponent implements OnInit {

  constructor() { }

  ngOnInit() {
  }

}

home.page.ts

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

@Component({
  selector: 'app-home',
  templateUrl: 'home.page.html',
  styleUrls: ['home.page.scss'],
})
export class HomePage {

}

home.module.ts

import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { IonicModule } from '@ionic/angular';
import { FormsModule } from '@angular/forms';
import { RouterModule } from '@angular/router';

import { HomePage } from './home.page';

@NgModule({
  imports: [
    CommonModule,
    FormsModule,
    IonicModule,
    RouterModule.forChild([
      {
        path: '',
        component: HomePage
      }
    ])
  ],
  declarations: [HomePage]
})
export class HomePageModule {}

home.page.html

<ion-header>
  <ion-toolbar>
    <ion-title>
      Ionic Blank
    </ion-title>
  </ion-toolbar>
</ion-header>

<ion-content padding>
  The world is your oyster.
  <p>If you get lost, the <a target="_blank" rel="noopener" href="https://ionicframework.com/docs">docs</a> will be your guide.</p>

  <app-test></app-test>
</ion-content>

And the folder structure as an image

我现在已经尝试了几件事,我发现一个解决方法是创建一个 src/app/shared.module.ts 文件并在那里声明和导出 TestComponent,然后在我想使用的每个页面中导入 SharedModule组件。

但是我觉得这种解决方法并不理想,而且我在如何更清洁方面缺少一些东西。有什么想法吗?

【问题讨论】:

    标签: ionic4


    【解决方案1】:

    您的共享模块解决方法实际上是 Angular 的一个好习惯,您应该坚持下去。

    供参考:https://angular.io/guide/sharing-ngmodules

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2019-03-23
      • 1970-01-01
      • 1970-01-01
      • 2019-12-09
      • 2017-09-26
      • 2019-08-30
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多