- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
tôi có một cái ModalComponent
如果我在我的 app.module.ts
中这样声明它,它工作正常,我可以在我的应用程序中使用它。
@NgModule({
declarations: [AppComponent, ModalComponent],
entryComponents: [ModalComponent],
...
})
现在,如果我在我的页面 page.module.ts
中做同样的事情,并尝试在那里使用模式,它就不起作用了。为什么?
我收到此错误 No component factory found for ... yadaayaydayada
我读到这可能是由于 ionic 4 而导致的过时脚本问题,因此我确保我的 gói.json
基础与他们的模板相同。
我理想的解决方案是在页面中显示来自组件的模式,但由于上述错误,我无法让它工作。
我需要如何注册我的组件,以便我可以在页面内和/或嵌套在该页面的组件内以编程方式绑定(bind)它?
下面有更多信息
这是我显示模态的方式:
async presentModal() {
const modal = await this.ui.modalController.create({
component: ModalComponent,
});
return await modal.present();
}
完成app.module.ts
//Omitting Imports
@NgModule({
declarations: [AppComponent, ModalComponent],
entryComponents: [ModalComponent],
imports: [
BrowserModule,
HttpModule,
FormsModule,
HttpClientModule,
OAuthModule.forRoot(),
IonicModule.forRoot(),
AppRoutingModule, // <-- This is where the Page is imported
],
nhà cung cấp: [
OAuthService,
UrlHelperService,
InAppBrowser,
StatusBar,
SplashScreen,
Camera,
WebView,
File,
FileTransfer,
VideoEditor,
{ provide: RouteReuseStrategy, useClass: IonicRouteStrategy },
{ provide: HTTP_INTERCEPTORS, useClass: UnAuthorizedService, multi: true, }
],
bootstrap: [AppComponent]
})
export class AppModule { }
đây là của tôiapp-routing.module.ts
import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
const routes: Routes = [
{ path: '', loadChildren: './battles/tabs/tabs.module#TabsPageModule' }, <-- page registered here
//omitting other routes
];
@NgModule({
imports: [RouterModule.forRoot(routes)],
exports: [RouterModule],
})
export class AppRoutingModule {}
đây là của tôitabs.router.module.ts
import { NgModule } from '@angular/core';
import { RouterModule, Routes } from '@angular/router';
import { TabsPage } from './tabs.page';
const routes: Routes = [
{
path: 'battles',
component: TabsPage,
những đứa trẻ: [
{
path: 'user',
những đứa trẻ: [
{
path: '',
loadChildren: '../user/user.module#UserPageModule' <-- Here is my page (I think this might be lazy loaded not sure.)
}
]
}
//Omitting other routes
]
}
];
@NgModule({
imports: [RouterModule.forChild(routes)],
exports: [RouterModule]
})
export class TabsPageRoutingModule { }
Đây làpage.module
import { NgModule } from '@angular/core';
import { FormsModule } from '@angular/forms';
import { CommonModule } from '@angular/common';
import { Routes, RouterModule } from '@angular/router';
import { IonicModule } from '@ionic/angular';
import { UserPage } from './user.page';
const routes: Routes = [
{
path: '',
component: UserPage
}
];
@NgModule({
imports: [
CommonModule,
FormsModule,
IonicModule,
RouterModule.forChild(routes)
],
declarations: [UserPage],
// I would declare my modal like this same as in the app.module,
// but this isn't working, for now I'm storing it in app.module
// declarations: [UserPage, ModalComponent],
// entryComponents: [ModalComponent],
})
export class UserPageModule { }
完整错误:
错误错误:未捕获( promise ):错误:未找到 ModalComponent 的组件工厂。你把它添加到@NgModule.entryComponents了吗?
我想是因为我的页面是延迟加载的,所以我正面临 vấn đề này由于缺乏 Angular 知识,我无法理解如何解决它。
câu trả lời hay nhất
此答案来自 Ionic FrameWork Forum 中的“razmans”
首先将 PageModule 导入到 app.module.ts 中,然后只有你可以导入到 Home 中。
应用程序模块.ts
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { RouterModule, 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 { AppRoutingModule } from './app-routing.module';
import { AppComponent } from './app.component';
import {FirstPageModule} from './first/first.module'
@NgModule({
declarations: [AppComponent],
entryComponents: [],
imports: [BrowserModule, IonicModule.forRoot(), AppRoutingModule,FirstPageModule],
nhà cung cấp: [
StatusBar,
SplashScreen,
{ provide: RouteReuseStrategy, useClass: IonicRouteStrategy }
],
bootstrap: [AppComponent]
})
export class AppModule {}
首页.ts
import { Component } from '@angular/core';
import { NavController,AlertController,ModalController } from '@ionic/angular';
import {FirstPage} from '../first/first.page';
@Component({
selector: 'app-page-home',
templateUrl: 'home.page.html',
styleUrls: ['home.page.scss']
})
export class HomePage {
constructor( private modalCtrl:ModalController,private alertCtrl:AlertController) {}
async moveToFirst()
{
const modal = await this.modalCtrl.create({
component: FirstPage
});
return await modal.present();
}
}
这将打开我的模式。关闭它是另一回事,而不是让 ViewController 来做它,你需要让 ModalController 用 this.modalCtrl.dismiss 来做它。这是我从 first.page.ts 关闭模态的方式
import { Component, OnInit } from '@angular/core';
import { NavController,ModalController } from '@ionic/angular';
@Component({
selector: 'first',
templateUrl: './first.page.html',
styleUrls: ['./first.page.scss'],
})
export class FirstPage implements OnInit {
constructor(private nav:NavController,private modalCtrl:ModalController) {}
ngOnInit() {
}
closeModal()
{
this.modalCtrl.dismiss();
}
关于angular - 错误在 Ionic 4 中找不到组件工厂...,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54188953/
我应该执行以下操作: 可能通过服务/工厂,使用 $q(异步)查询 API 以获取大型名称数据集 有另一个服务(也是异步的),它应该只返回上述工厂的元素,如果它们与某个字符串(搜索字段)匹配。目的是缩小
我有一个通用的基类。我有一个实现基类的具体类。 我将如何创建工厂类/方法来交付不同类型的具体类? 举个例子: public class ReceiverBase where T : IInte
我正在查看以下链接中的 Ninject Factory 扩展: http://www.planetgeek.ch/2011/12/31/ninject-extensions-factory-intro
工厂、提供商和服务这三个术语之间有什么区别? 刚刚了解 NHibernate 及其存储库模式(POCO 类等)。 最佳答案 工厂:通过将一堆位组合在一起或基于某种上下文选择类型来组装类 Provide
使用CGLIB我可以做到 final var enhancer = new Enhancer(); enhancer.setUseCache(false); enhancer.setSuperclas
我试图在 Kotlin 中使用伴随对象工厂方法(相当于 Java 中的静态工厂方法)创建一个嵌套内部类。这是我的代码的简化版本。 class OuterClass { var myData:L
我正在为我的大学做一个项目,但遇到了问题。 基本上,该项目由一个客户端-服务器应用程序组成,我想创建一个用于通信的 Packet 类。数据包由 header 和主体组成。现在问题来了。我可以有一些不同
这个问题在这里已经有了答案: Why doesn't polymorphism work without pointers/references? (6 个答案) What is object sl
我正在制作一个套接字工厂。我希望每个外部应用程序都使用 Socket 类的接口(interface),它是几个类(ServerSocketTCP、ClientSocketTCP、ServerSocke
我是 angularjs 的新手,我正在尝试创建一个小型电影数据库。这是我第一次使用工厂,我想确保这是正确的方法,以及如何在另一个功能中使用这个工厂,如下所示? 我希望这个工厂只运行一次,这样我就可以
这个问题在这里已经有了答案: Java inner class and static nested class (28 个答案) 关闭 5 年前。 public class DataFactory
我看过很多关于 C++ 工厂的帖子,但到目前为止我还没有看到解决我的问题的解决方案。 (虽然我可能遗漏了一些东西。) 示例控制台应用程序: #include #include #include
这是一个简单的 C++ 项目,有 2 种设计模式:单例和工厂,sigleton 也是一个模板化类,一个接口(interface) (IHash) 和一个类 (Hash1)。一个简单的工厂类 (Hash
这个问题类似于Factory and generics ,并且可能有相同的答案,但它是不同的。我有一个通用基类,它将由完全独立的 JAR 中的类进行扩展。所述 JAR 应该能够在不更改任何其他代码的情
问题是我需要为传递的类创建一个新实例 有没有办法重写这个函数,让它可以接受任意数量的参数? function createInstance(ofClass, arg1, arg2, arg3, ...
我想用简单的 C++ 语法创建一个简单的工厂方法: void *createObject(const char *str,...) { if(!strcmp("X",str)) retu
经过大约 10 个月的程序化 PHP 学习后,我现在正尝试着手研究基本的 OOP 原则和设计模式。这是一个爱好,我没有那么多时间去追求它,所以请原谅这个问题的水平很低。 我的网站(目前 100% 程序
我有一个简单的问题。 我如何编写一个工厂来定义使用 make() 或 create() 的关系,具体取决于原始调用 make() 还是 create()? 这是我的用例: 我有一个简单的工厂 /**
我正在尝试在延迟加载模块中提供 APP_BASE_HREF 注入(inject) token ,然而,工厂方法根本没有被调用。 在这里https://github.com/MaurizioCascia
我有以下 ast: import { factory as f } from 'typescript' const typeDeclaration = f.createTypeAliasDeclara
Tôi là một lập trình viên xuất sắc, rất giỏi!