官术网_书友最值得收藏!

Responsive and fluid layout

Responsive layout is achieved by applying additional classes to the columns. Four screen sizes are supported with different breakpoints.

Prefix Device Size ui-sm-* Small devices like phones max-width: 640px ui-md-* Medium-sized devices like tablets min-width: 641px ui-lg-* Large-sized devices like desktops min-width: 1025px ui-xl-* Big screen monitors min-width: 1441px

 

When an element features multiple style classes listed in the table, they get applied from the bottom to the top. Let's take an example:

<div class="ui-g">
<div class="ui-g-12 ui-md-6 ui-lg-2">ui-g-12 ui-md-6 ui-lg-2</div>
<div class="ui-g-12 ui-md-6 ui-lg-2">ui-g-12 ui-md-6 ui-lg-2</div>
<div class="ui-g-12 ui-md-4 ui-lg-8">ui-g-12 ui-md-4 ui-lg-8</div>
</div>

What is happening here?

  • On large screens, three columns are displayed in proportion 2:12, 2:12, and 8:12.
  • On medium screens, two rows are displayed. The first row has equal columns and the second row has a column 4:12.
  • On small screens (mobile devices) columns get stacked--each column is displayed in its own row.

The screenshot shows the arrangement of columns on medium-sized devices:

PrimeNG components have a built-in responsive mode. They understand a special ui-fluid style class. The Grid CSS and any other grid system can be used together with this style class, which provides a 100% width to components. This behavior helps to use the screen space efficiently. An example demonstrates various components in the fluid layout:

<div class="ui-fluid ui-corner-all">
<div class="ui-g">
<div class="ui-g ui-g-12 ui-md-6 ui-g-nopad">
<div class="ui-g-12 ui-md-3 ui-label">
Passenger
</div>
<div class="ui-g-12 ui-md-9">
<input pInputText type="text"/>
</div>
</div>
<div class="ui-g ui-g-12 ui-md-6 ui-g-nopad">
<div class="ui-g-12 ui-md-3 ui-label">
Flight day
</div>
<div class="ui-g-12 ui-md-9">
<p-calendar [(ngModel)]="date" [showIcon]="true">
</p-calendar>
</div>
</div>
</div>
<div class="ui-g">
<div class="ui-g ui-g-12 ui-md-6 ui-g-nopad">
<div class="ui-g-12 ui-md-3 ui-label">
Notice
</div>
<div class="ui-g-12 ui-md-9">
<textarea pInputTextarea type="text"></textarea>
</div>
</div>
<div class="ui-g ui-g-12 ui-md-6 ui-g-nopad">
<div class="ui-g-12 ui-md-3 ui-label">
Destination
</div>
<div class="ui-g-12 ui-md-9">
<p-listbox [options]="cities" [(ngModel)]="selectedCity">
</p-listbox>
</div>
</div>
</div>
</div>

The layout from medium up to big screens looks as follows:

The layout on small screens has stacked columns:

As you can see, all right-aligned labels become left aligned. You can achieve this behavior with media queries:

.ui-fluid .ui-g .ui-label {
text-align: right;
white-space: nowrap;
}

@media screen and (max-width: 640px) {
.ui-fluid .ui-g .ui-label {
text-align: left;
}
}
The complete demo application with instructions is available on GitHub at
https://github.com/ova2/angular-development-with-primeng/tree/master/chapter2/primeng-grid-css.
主站蜘蛛池模板: 睢宁县| 宣汉县| 永定县| 石柱| 大宁县| 肇源县| 科技| 乐陵市| 汝南县| 沧州市| 朝阳区| 航空| 沛县| 南通市| 石阡县| 青铜峡市| 临潭县| 东乌珠穆沁旗| 柏乡县| 五指山市| 普洱| 苏尼特右旗| 精河县| 靖宇县| 沾益县| 顺平县| 连城县| 宁晋县| 丰城市| 衡阳县| 淮滨县| 上林县| 仲巴县| 大石桥市| 呼和浩特市| 富裕县| 平远县| 栾川县| 万宁市| 浠水县| 长兴县|