Google AMP - История
Amp-story - это компонент-amp-компонент, используемый для отображения контента, удерживая пользователя в курсе истории. Например, используя серию изображений, рассказывающих о бренде.
Чтобы начать работу с amp-story, нам нужно включить скрипт, как показано ниже -
<script async custom-element = "amp-story"
src = "https://cdn.ampproject.org/v0/amp-story-1.0.js">
</script>
В этой главе давайте разберемся, что такое amp-story и как они работают. Предположим, у нас есть галерея изображений, и мы хотим отобразить ее на странице. На странице amp мы можем сделать ее красивой и интерактивной для пользователя с помощью компонента amp-story.
Формат тега amp-story выглядит так, как показано ниже -
<amp-story standalone> ---> Main story Tag
<amp-story-page id = "page-1"> ---> Pages inside the story e.g page1
<amp-story-grid-layer template = "fill"> -->
Layers for the page1.You can have more than one layer.
//Add html elements here or amp components
</amp-story-grid-layer>
<amp-story-grid-layer template = "fill"> -->
Layers for the page1.You can have more than one layer.
//Add html elements here or amp components
</amp-story-grid-layer>
...
</amp-story-page>
<amp-story-page id = "page-2"> ---> Pages inside the story e.g page2
<amp-story-grid-layer template = "fill"> -->
Layers for the page2.You can have more than one layer.
//Add html elements here or amp components
</amp-story-grid-layer>
...
</amp-story-page>
...
</amp-story>
Для amp-story добавлены следующие дополнительные атрибуты:
<amp-story standalone title = "My Story"
publisher = "The AMP Team"
publisher-logo-src = "publisherlogo image here"
poster-portrait-src = "poster portrait here"
poster-square-src = "poster square image here"
poster-landscape-src = "poster landscape image here">
Эта функция делает рассказывание историй с помощью усилителя очень интерактивным.
В следующем коде показан рабочий пример для amp-story. Вывод для них показан как для настольного, так и для мобильного режима.
пример
<!doctype html>
<html amp lang = "en">
<head>
<meta charset = "utf-8">
<script async src = "https://cdn.ampproject.org/v0.js"></script>
<script async custom-element = "amp-story" src = "https://cdn.ampproject.org/v0/amp-story-1.0.js"></script>
<title>Google AMP - Story</title>
<meta name = "viewport" content = "width = device-width,minimum-scale = 1,initial-scale=1">
<link rel = "canonical" href = "/stories/introduction/amp_story_hello_world/">
<style amp-boilerplate>
body{
-webkit-animation:
-amp-start 8s steps(1,end) 0s 1 normal both;-moz-animation:
-amp-start 8s steps(1,end) 0s 1 normal both;-ms-animation:
-amp-start 8s steps(1,end) 0s 1 normal both;animation:
-amp-start 8s steps(1,end) 0s 1 normal both
}
@-webkit-keyframes
-amp-start{from{visibility:hidden}to{visibility:visible}}@-moz-keyframes
-amp-start{from{visibility:hidden}to{visibility:visible}}@-ms-keyframes
-amp-start{from{visibility:hidden}to{visibility:visible}}@-o-keyframes
-amp-start{from{visibility:hidden}to{visibility:visible}}@keyframes
-amp-start{from{visibility:hidden}to{visibility:visible}}
</style>
<noscript>
<style amp-boilerplate>
body{
-webkit-animation:
none;-moz-animation:none;
-ms-animation:none;
animation:none}
</style>
</noscript>
<style amp-custom>
amp-story {
font-family: Roboto, Helvetica, Arial, sans-serif;
}
amp-story-page * {
color: white;
text-align: center;
}
</style>
</head>
<body>
<amp-story standalone title = "Stories in AMP - Hello World" publisher = "AMP Project">
<amp-story-page id = "page-1">
<amp-story-grid-layer template = "fill">
<amp-img src = "images/christmas1.jpg"
width = "300" height = "250"
layout = "responsive">
</amp-img>
</amp-story-grid-layer>
<amp-story-grid-layer template = "vertical">
<h1>Hello World</h1>
<p>This is an AMP Story.</p>
</amp-story-grid-layer>
</amp-story-page>
<amp-story-page id = "page-2">
<amp-story-grid-layer template = "fill">
<amp-img src = "images/christmas5.jpg"
width = "300" height = "250"
layout = "responsive">
</amp-img>
</amp-story-grid-layer>
<amp-story-grid-layer template = "vertical">
<h1>Hello World</h1>
<p>This is an AMP Story.</p>
</amp-story-grid-layer>
</amp-story-page>
<amp-story-page id = "page-3">
<amp-story-grid-layer template = "fill">
<amp-img src = "images/christmas3.jpg"
width = "300" height = "250"
layout = "responsive">
</amp-img>
</amp-story-grid-layer>
<amp-story-grid-layer template = "vertical">
<h1>Hello World</h1>
<p>This is an AMP Story.</p>
</amp-story-grid-layer>
</amp-story-page>
<amp-story-page id = "page-4">
<amp-story-grid-layer template = "fill">
<amp-img src = "images/christmas4.jpg"
width = "300" height="250"
layout = "responsive">
</amp-img>
</amp-story-grid-layer>
<amp-story-grid-layer template = "vertical">
<h1>Hello World</h1>
<p>This is an AMP Story.</p>
</amp-story-grid-layer>
</amp-story-page>
<amp-story-bookend src = "ampstory.json" layout = "nodisplay">
</amp-story-bookend>
</amp-story>
<body>
</html>
ampstory.json
{
"bookendVersion": "v1.0",
"shareProviders": [
"email",
"twitter",
"tumblr",
{
"provider": "facebook",
"app_id": "254325784911610"
}
],
"components": [
{
"type": "heading",
"text": "Introduction"
},
{
"type": "small",
"title": "Next Story is on Car Brands",
"url": "ampcarbrand.html",
"image": "images/audi.jpg"
}
]
}
Вывод на рабочий стол
data:image/s3,"s3://crabby-images/1a603/1a603a897e034fdafaadc378e98880683cae0e79" alt=""
data:image/s3,"s3://crabby-images/63913/63913e2964e17bc72dddc6201d0fea855c008395" alt=""
data:image/s3,"s3://crabby-images/86749/8674918f2f3b679f014f54ca329ad994468c1e04" alt=""
data:image/s3,"s3://crabby-images/7acd5/7acd5ed5524f70999ddafbf78905e044393e8555" alt=""
Так отображается раздел истории. Вы также можете добавить видео или любой другой компонент amp, чтобы сделать историю более интерактивной.
Как только он достигнет конца истории, он покажет, что указано в amp-bookend, как показано ниже -
<amp-story-bookend
src = "ampstory.json" layout = "nodisplay">
</amp-story-bookend>
Мы передали amp-bookend файл ampstory.json. В json-файле содержится подробная информация о предварительном просмотре следующей истории, как показано ниже. Когда пользователь нажимает на три точки, показанные справа, отображается следующий экран -
data:image/s3,"s3://crabby-images/f74f3/f74f358f0dc30c054dcf7a31f6b24127bee709fd" alt=""
Это дает кнопку воспроизведения, которая снова загрузит историю. Вы можете щелкнуть изображение автомобиля, чтобы отобразить историю марок автомобилей.
Выход в мобильном режиме выглядит следующим образом -
data:image/s3,"s3://crabby-images/28358/283589678c1acf793ef356fa322cad1d26133110" alt=""
data:image/s3,"s3://crabby-images/d2e99/d2e99db191f62197bb8767de1c332e4ecc6a79ff" alt=""
data:image/s3,"s3://crabby-images/945da/945daec5ff8060b90e0865229b38d6fc305ea525" alt=""