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

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)
主站蜘蛛池模板: 嘉兴市| 错那县| 历史| 佳木斯市| 揭阳市| 拜城县| 马边| 石楼县| 根河市| 张掖市| 巴青县| 黎平县| 牡丹江市| 海淀区| 清流县| 江口县| 喀喇| 延寿县| 治多县| 喀喇沁旗| 巨野县| 淮北市| 辽阳县| 昌图县| 岑溪市| 竹北市| 安西县| 宁德市| 乡城县| 江城| 大足县| 肇庆市| 威信县| 威海市| 兴文县| 南丹县| 威信县| 盐源县| 银川市| 廊坊市| 庄河市|