Bel*_*lgi 5 radio-button angular-material angular
我从这里开始运行一个单选按钮的示例,由于没有这样的文件(我的应用程序是cli创建的),因此请确保遵循附录中的所有说明。
包含html模板后,我的应用将无法呈现,并且在控制台中出现错误:
无法绑定到“值”,因为它不是“ md-radio-button”的已知属性
我的ts文件:
import { Component, OnInit } from '@angular/core';
import { SlidesService } from 'app/slides/slides.service';
import { Slide } from 'app/slides/slide';
import { Observable } from 'rxjs/Rx';
import { Subscription } from 'rxjs/Subscription';
import { MdButtonModule, MdCheckboxModule } from '@angular/material';
@Component({
selector: 'app-question',
templateUrl: './question.component.html',
styleUrls: ['./question.component.css']
})
export class QuestionComponent implements OnInit {
constructor(private _slidesService: SlidesService) { }
slides: Slide[];
currSlide: Slide;
favoriteSeason: string;
seasons = [
'Winter',
'Spring',
'Summer',
'Autumn',
];
ngOnInit() {
this._slidesService.getSlides()
.subscribe(slides => {
this.slides = slides
this.currSlide = slides[0];
},
error => console.log(<any>error));
}
}
Run Code Online (Sandbox Code Playgroud)
我的html文件:
<div class="well well-lg" *ngIf='slides && slides.length'>
<img [src]='slides[0].imageUrl'>
<h1>{{currSlide.SongTitle}}</h1>
<md-radio-group class="example-radio-group" [(ngModel)]="favoriteSeason">
<md-radio-button class="example-radio-button" *ngFor="let season of seasons" [value]="season">
{{season}}
</md-radio-button>
</md-radio-group>
<div class="example-selected-value">Your favorite season is: {{favoriteSeason}}</div>
</div>
Run Code Online (Sandbox Code Playgroud)
AppModule:
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { FormsModule } from '@angular/forms';
import { HttpModule } from '@angular/http';
import { AlertModule } from 'ngx-bootstrap';
import { CarouselModule } from 'ngx-bootstrap/carousel';
import { AppComponent } from './app.component';
import { SlidesComponent } from './slides/slides.component';
import { SlidesService } from './slides/slides.service';
import { QuestionComponent } from './question/question.component';
import { MdButtonModule, MdCheckboxModule } from '@angular/material';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
import { FormControl, FormGroup } from '@angular/forms';
import { MaterialModule } from '@angular/material';
import { ReactiveFormsModule } from '@angular/forms';
@NgModule({
declarations: [
AppComponent,
SlidesComponent,
QuestionComponent
],
imports: [ReactiveFormsModule, MaterialModule,
BrowserAnimationsModule,
MdButtonModule,
MdCheckboxModule,
BrowserModule,
FormsModule,
HttpModule,
AlertModule.forRoot(),
CarouselModule.forRoot()
],
providers: [SlidesService],
bootstrap: [AppComponent]
})
export class AppModule { }
Run Code Online (Sandbox Code Playgroud)
感谢您提出解决此问题的建议。
由于这似乎尚未得出结论,因此我想提供答案,所有的功劳都归功于尼尔·伦恩(Neil Lunn)!
正如Sajeetharan的答案适用于MaterialModule进口商品,但正如Neil Lunn所说:
您应该只导入“必需”模块
因为否则
这将导致更大的构建包。
因此,只需导入MdRadioModule到您的应用模块并将其添加到imports数组即可解决此问题:
import { MdRadioModule } from '@angular/material';
imports: [
....
MdRadioModule,
....
],
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
23773 次 |
| 最近记录: |