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

Using CSS3 flexbox for layout in AMP

AMP is a modern framework, and has been built with modern priorities such as performance at its core. It makes use of modern web technologies, and this includes support for CSS3 and the Flexible Box Model (flexbox). Flexbox is often regarded as an improvement over the Box Model as it doesn't use floats.

Let's see if there's a better way to achieve our desired layout with flexbox. First, remove the float:left style from the .related-thumb amp-img selector that we added in the last section. Then apply the following styles to the figure items, using .related-thumb to target them (full code at /ch3/related-flex.html):

.related-thumb {
display:flex;
align-items: center;
}

The AMP-HTML markup for our list should look like this (first two items shown):

<ul class="related-items">
<li>
<figure class="related-thumb">
<amp-img src="img/penguin.jpg" width="125" height="75" layout="fixed">
</amp-img>
<figcaption>
If a penguin can find a soul mate, I'm sure I can too
<span class="author">Rebekah Crane</span>
</figcaption>
</figure>
</li>

<li>
<figure class="related-thumb">
<amp-img src="img/cat.jpg" width="125" height="75" layout="fixed">
</amp-img>
<figcaption>
What greater gift than the love of a cat
<span class="author">Charles Dickens</span>
</figcaption>
</figure>
</li>
...
</ul>

Applying flex to the figure element means its children will expand to fill the available space. Note the use of layout="fixed" on the amp-img tags here. While we don't mind the headline stretching or shrinking to fit into the available space, we want all the images to remain the same size. (Technically though, according to the table we saw earlier, since we have already specified width and height, layout="fixed" will be inferred if the attribute is absent; we've left it in here to be explicit.)

Related content thumbnail images displaying incorrectly on narrow viewports

Nearly there! It looks good on wider screens, but not so great on narrow ones, as shown in the preceding image. We also need to impose a minimum width on our images, otherwise a longer headline can affect the width of the associated thumbnail image, resulting in a nonuniform layout:

.related-thumb amp-img {
min-width: 125px;
margin-right:5px;
}

This results in a correctly aligned list on small screens, as shown in the following image:

Related content thumbnails correctly aligned on small screens (/ch3/related-flex.html)
主站蜘蛛池模板: 甘南县| 龙里县| 苏尼特左旗| 东明县| 固阳县| 高州市| 台湾省| 东丰县| 石首市| 罗定市| 金堂县| 沧源| 明光市| 南昌市| 辽宁省| 东平县| 会泽县| 黑水县| 淄博市| 京山县| 六安市| 蕉岭县| 上杭县| 安国市| 剑阁县| 祁门县| 张掖市| 汕尾市| 海门市| 迭部县| 菏泽市| 德钦县| 崇阳县| 西藏| 北海市| 米泉市| 分宜县| 新昌县| 峨眉山市| 凤山市| 应城市|