stycznia 2017 Aktualizacja:
kątowa 2 zespół niedawno dodał nowy pakiet NPM flex-layout tylko układ. Jest to oddzielne opakowanie niezależne od materiału kątowego.
Pełne instrukcje są dostępne w pliku README github page.
instalacja modułu:
npm instalacji @ kątową/giętki układ oszczędzające
W app.module.ts (lub równoważny), stwierdzenie, że moduł:
import {FlexLayoutModule} from "@angular/flex-layout";
@NgModule({
imports: [
...
FlexLayoutModule
],
...
})
Przykładowy przykład:
<div class="flex-container"
fxLayout="row"
fxLayout.xs="column"
fxLayoutAlign="center center"
fxLayoutAlign.xs="start">
<div class="flex-item" fxFlex="20%" fxFlex.xs="40%"> </div>
<div class="flex-item" fxFlex> </div>
<div class="flex-item" fxFlex="25px"> </div>
</div>
Oto plunker sample zaczerpnięty ze strony github z układem flex.
Original Odpowiedź:
docs którego się odnosimy się do angular1 materiału. Materiał Angular2 nadal nie ma żadnych dyrektyw dotyczących układu.
Możesz samodzielnie utworzyć dyrektywę w prosty sposób.
Wszystko, co musisz wiedzieć:
layout="row"
jest taka sama jak style="display:flex;flex-direction:row"
layout="column"
=>style="display:flex;flex-direction:column"
I flex
jest równa style="flex:1"
As dyrektyw:
@Directive({
selector:'[layout]'
})
export class LayoutDirective{
@Input() layout:string;
@HostBinding('style.display') display = 'flex';
@HostBinding('style.flex-direction')
get direction(){
return (this.layout === 'column') ? 'column':'row';
}
}
W dyrektywie Flex stosuje się ją w następujący sposób: <div flex>
lub <div flex="10">
dowolna liczba od 0 do 100%.Ponadto, po prostu dla zabawy, dodałem kurczyć i rozwijać wejścia
@Directive({
selector:'[flex]'
})
export class FlexDirective{
@Input() shrink:number = 1;
@Input() grow:number = 1;
@Input() flex:string;
@HostBinding('style.flex')
get style(){
return `${this.grow} ${this.shrink} ${this.flex === '' ? '0':this.flex}%`;
}
}
Aby z nich korzystać wszędzie bez dodawania ich do każdego składnika:
@NgModule({
imports: [ BrowserModule ],
declarations: [ AppComponent,FlexDirective ,LayoutDirective ],
bootstrap: [ AppComponent ]
})
export class AppModule { }
Oto przykład w plunk
Już pierwsze wiersze dokumentu zawierają instrukcje dotyczące importowania go, jeśli używasz SystemJS. Czy widzisz w Narzędziach deweloperskich prośby o CSS? –
Mam działające składniki (takie jak Button - zaktualizowałem mój plik konfiguracyjny SystemJs), ale układ nie działa. Nie widzę żadnej prośby o jakąkolwiek materialną konstrukcję css. –