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

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)
主站蜘蛛池模板: 梅州市| 五原县| 灌云县| 迁安市| 固原市| 江津市| 珲春市| 句容市| 双柏县| 洪湖市| 阿拉善左旗| 双鸭山市| 沁水县| 蕉岭县| 高雄市| 霸州市| 弋阳县| 濮阳市| 河北省| 遂溪县| 赤壁市| 五华县| 会宁县| 开阳县| 佳木斯市| 南昌市| 德兴市| 江华| 且末县| 石河子市| 维西| 尉犁县| 保靖县| 嘉黎县| 海晏县| 香格里拉县| 龙泉市| 西丰县| 芦山县| 娱乐| 双辽市|