2017-04-25 14 views
3

MdDialogを使用してウィンドウをポップアップしようとしました。しかし、空白のウィンドウしか表示されません。内容はありません。Angular2 MdDialogはコンテンツを表示せず、ウィンドウのみを表示します

dialog.component.ts:

import {Component, NgModule, ViewContainerRef} from '@angular/core' 
import {BrowserModule} from '@angular/platform-browser' 

import { MaterialModule } from '@angular/material'; 
import { BrowserAnimationsModule } from '@angular/platform-browser/animations'; 
import { MdDialog, MdDialogConfig, MdDialogRef } from '@angular/material'; 

@Component({ 
    selector: 'dialog', 
    template: ` 
     <h1 md-dialog-title>Dialog</h1> 
     <h2>Hi, I am the dialog</h2> 
     <button md-raised-button (click)="dialogRef.close()">Close dialog</button> 
    ` 
}) 

export class DialogComponent { 
    constructor(public dialogRef : MdDialogRef<any>){}; 
} 

fileuploader.component.ts私はなって何

import { Component } from '@angular/core'; 
import '../../assets/css/styles.css'; 
import { FileUploader } from 'ng2-file-upload'; 
import { DialogComponent } from './dialog.component'; 
import {MdDialog, MdDialogConfig, MdDialogRef} from '@angular/material'; 
import {NgModule, ViewContainerRef} from '@angular/core' 
import {BrowserModule} from '@angular/platform-browser' 
import { MaterialModule } from '@angular/material'; 
import { BrowserAnimationsModule } from '@angular/platform-browser/animations'; 

@Component({ 
    selector: 'file-uploader', 
    templateUrl: '../templates/fileuploader.component.html', 
    styleUrls: ['../css/fileuploader.component.css'] 
}) 

/** Class representing App Component. */ 
export class FileUploaderComponent { 


    constructor(
    public dialog : MdDialog, 
) { 


     console.log("ImageUpload:uploaded:", item, status, response, headers); 
     console.log("test"); 
     let dialogRef = this.dialog.open(DialogComponent, { 
     height: '400px', 
     width: '600px', 
     }); 

     dialogRef.afterClosed().subscribe(result => { 
     dialogRef = null; 
     }); 

     console.log("done"); 
    }; 
    } 
} 

app.module.ts

import { NgModule } from '@angular/core'; 
import { BrowserModule } from '@angular/platform-browser'; 
import { RouterModule, Routes } from '@angular/router'; 
import { FormsModule } from '@angular/forms'; 
import { AngularFireModule, AuthProviders, AuthMethods } from 'angularfire2'; 
import { AppComponent } from './components/app.component'; 
import { LoginComponent } from './components/login.component'; 
import { DashboardComponent } from './components/dashboard.component'; 
import { BrowserAnimationsModule } from '@angular/platform-browser/animations'; 
import { LoggedInGuard } from './common/logged-in.guard'; 
import { MaterialModule } from '@angular/material'; 
import { HeaderComponent } from './components/header.component'; 
import { FileUploaderComponent } from './components/fileuploader.component'; 
import { FileDropDirective, FileSelectDirective } from 'ng2-file-upload'; 
import { DialogComponent } from'./components/dialog.component'; 


/** 
* App Module 
* The app module handles all the imports, 
* declerations, exports and providers. Any new 
* component need to be declared here. 
*/ 

@NgModule({ 
    imports: [ 
    BrowserModule, 
    AngularFireModule.initializeApp(firebaseConfig, firebaseAuthConfig), 
    RouterModule.forRoot(appRoutes), BrowserAnimationsModule, 
    MaterialModule.forRoot() 
    ], 
    declarations: [ 
    AppComponent, LoginComponent, DashboardComponent, HeaderComponent, 
    FileUploaderComponent, FileSelectDirective, FileDropDirective, DialogComponent 
    ], 
    entryComponents: [ 
    DialogComponent 
    ], 
    exports: [], 
    providers: [LoggedInGuard], 
    bootstrap: [AppComponent] 
}) 
/** Class representing App Module. */ 
export class AppModule { } 

ウィンドウをポップアップすることであり、ダイアログコンポーネントにメッセージを表示します。「ダイアログ」「こんにちは、私はダイアログです」。しかし、今は空白の窓です。

ありがとうございます。

答えて

3

問題はセレクタのことです。 "ダイアログ"セレクタがあまりにも一般的で、素材パッケージと混同されているようです。より具体的なダイアログに変更してください。それはうまく動作します。

+0

私はダイアログに名前を付けてはならないと知っていました。これを投稿してくれてありがとう、私の勇気を聞いたことがあり、私に数時間のデバッグを救った。 –

関連する問題