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

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)
主站蜘蛛池模板: 邳州市| 商河县| 宁德市| 巴彦淖尔市| 科尔| 太湖县| 温宿县| 衡水市| 湘潭县| 钦州市| 县级市| 临猗县| 兴隆县| 曲阳县| 武清区| 南陵县| 扶沟县| 广昌县| 扎赉特旗| 安平县| 凤山市| 永宁县| 保靖县| 江山市| 桦川县| 枞阳县| 大同县| 伊通| 德阳市| 新竹县| 定结县| 黄梅县| 城固县| 萝北县| 鹿泉市| 曲阜市| 鹿泉市| 芦溪县| 错那县| 手机| 周宁县|