درباره این codelab
1. مقدمه
AMP ساخت صفحات وب قابل اعتماد، پاسخگو و کارآمد را آسان تر می کند. AMP به شما امکان می دهد بدون نوشتن جاوا اسکریپت، تعاملات رایج سایت ایجاد کنید. وب سایت amp.dev شامل قالب های از پیش طراحی شده با شروع سریع است.
چیزی که خواهی ساخت
در این لبه کد، شما یک صفحه AMP کاملا واکنشگرا، تعاملی و زیبا میسازید که بسیاری از ویژگیهای AMP و اجزای توسعهیافته را در خود جای داده است:
|
آنچه شما نیاز دارید
- یک مرورگر وب مدرن
- Node.js و یک ویرایشگر متن یا دسترسی به CodePen یا یک زمین بازی آنلاین مشابه
- دانش اولیه HTML، CSS، جاوا اسکریپت و ابزارهای توسعه دهنده گوگل کروم
2. در حال راه اندازی
ابزاری برای ارائه محتوا
ما از Node.js برای اجرای یک سرور HTTP محلی برای ارائه صفحه AMP خود استفاده خواهیم کرد. وب سایت Node.js را بررسی کنید تا نحوه نصب آن را بیاموزید.
ابزار انتخابی ما برای ارائه محتوا به صورت محلی، سرویس است، یک سرور محتوای ثابت مبتنی بر Node.js. برای نصب آن دستور زیر را اجرا کنید:
npm install -g serve
یک قالب را از amp.dev دانلود کنید
قالبهای AMP مخزنی از قالبها و مؤلفههای AMP با راهاندازی سریع است که به شما کمک میکند تا صفحات AMP مدرن و واکنشگرا را سریع ایجاد کنید.
از قالبهای AMP دیدن کنید و کد «مقاله ساده» قالب «بهترین عکسهای حیوانات سال» را دانلود کنید.
اجرای کد قالب
محتویات فایل ZIP را استخراج کنید.
دستور serve
را در داخل پوشه article
اجرا کنید تا فایل ها به صورت محلی ارائه شوند.
در مرورگر خود از http://localhost:5000/templates/article.amp.html دیدن کنید. (بسته به نسخه serve
ممکن است پورت 3000 یا عدد متفاوتی باشد. برای آدرس دقیق کنسول را بررسی کنید.)
در حالی که در حال انجام آن هستیم، بیایید Chrome DevTools را باز کنیم و حالت Device را نیز تغییر دهیم.
کد قالب را برش دهید
در این مرحله، ما یک صفحه AMP عمدتاً کارآمد را ایجاد کردهایم، اما هدف از این نرمافزار این است که شما یاد بگیرید و تمرین کنید، بنابراین...
همه چیز داخل <body></body>
حذف کنید.
اکنون ما با یک صفحه خالی می مانیم که فقط حاوی کد دیگ بخار است:
در سراسر این نرم افزار کد، اجزای زیادی را به این صفحه خالی اضافه خواهید کرد و تا حدی الگو را با عملکردهای بیشتر بازسازی خواهید کرد.
3. چه چیزی یک صفحه AMP را می سازد
یک صفحه AMP یک صفحه HTML با برچسب های اضافی و با برخی محدودیت ها برای عملکرد قابل اعتماد است.
اگرچه بیشتر تگها در یک صفحه AMP تگهای معمولی HTML هستند، برخی از تگهای HTML با برچسبهای خاص AMP جایگزین میشوند. این عناصر سفارشی که اجزای AMP HTML نامیده می شوند، اجرای الگوهای رایج را به روشی کارآمد آسان می کنند.
ساده ترین فایل AMP HTML به این شکل است (گاهی اوقات به عنوان AMP boilerplate نیز شناخته می شود):
<!doctype html>
<html ⚡>
<head>
<meta charset="utf-8">
<link rel="canonical" href="hello-world.html">
<meta name="viewport" content="width=device-width,minimum-scale=1,initial-scale=1">
<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>
<script async src="https://cdn.ampproject.org/v0.js"></script>
</head>
<body>Hello World!</body>
</html>
به کد صفحه خالی که در حین راهاندازی ایجاد کردهاید، نگاهی بیندازید، که شامل این دیگ بخار است و چند اضافات دارد— مهمتر از همه، یک <style amp-custom>
که شامل تعداد زیادی CSS کوچک شده است.
AMP در مورد طراحی نظری ندارد و مجموعه خاصی از سبک ها را اعمال نمی کند. اکثر اجزای AMP یک ظاهر طراحی بسیار ابتدایی دارند. این به نویسندگان صفحه واگذار می شود که CSS سفارشی خود را ارائه دهند. اینجاست که <style amp-custom>
وارد عمل می شود.
با این حال، الگوهای AMP ، سبکهای CSS خود را ارائه میدهند که به زیبایی طراحی شده، دارای مرورگر متقابل و پاسخگو هستند تا به شما در ایجاد سریع صفحات AMP زیبا کمک کنند. کد قالبی که دانلود کردهاید شامل این سبکهای CSS در <style amp-custom>.
4. پوسته صفحه خود را ایجاد کنید
برای ایجاد پوسته ای برای صفحه خود، از جمله منوی پیمایش، تصویر سرصفحه و عنوان، برخی از مؤلفه هایی را که از الگو حذف کرده ایم، دوباره اضافه می کنیم.
از صفحه مؤلفههای رابط کاربری AMP Start کمک میگیریم، اما جزئیات پیادهسازی آنها را عمیقاً بررسی نمیکنیم. مراحل بعدی در کد لبه فرصت های زیادی را برای انجام این کار فراهم می کند.
ناوبری پاسخگو را اضافه کنید
به https://ampstart.com/components#navigation بروید و کد HTML ارائه شده برای RESPONSIVE MENUBAR را در body
صفحه خود کپی و جایگذاری کنید.
کد ارائه شده توسط AMP Start شامل ساختار کلاس HTML و CSS لازم برای پیاده سازی یک نوار ناوبری پاسخگو برای صفحه شما است.
آن را امتحان کنید: اندازه پنجره خود را تغییر دهید تا ببینید چگونه به اندازه های مختلف صفحه نمایش پاسخ می دهد.
این کد از پرس و جوهای رسانه ای CSS و کامپوننت های amp-sidebar و amp-accordion AMP استفاده می کند.
تصویر و عنوان قهرمان را اضافه کنید
AMP Start قطعه های آماده برای استفاده را برای تصاویر و عناوین قهرمان زیبا و پاسخگو نیز فراهم می کند.
به https://ampstart.com/components#media بروید و کد HTML ارائه شده برای Fullpage Hero را درست بعد از نظر <!-- End Navbar --> comment
در متن کپی و در کد خود جایگذاری کنید body.
بیایید تصویر و عنوان را اکنون به روز کنیم.
همانطور که ممکن است متوجه شده باشید، دو تگ amp-img
مختلف در قطعه کد وجود دارد. یکی برای عرض های کوچکتر استفاده می شود و باید به تصویری با وضوح کمتر اشاره کند و دیگری برای نمایشگرهای بزرگتر. آنها به طور خودکار بر اساس ویژگی media
، که AMP در تمام عناصر AMP پشتیبانی می کند تغییر می کنند.
با جایگزین کردن <figure>...</figure>
موجود، src
، width
و height
را به تصاویر مختلف و عنوان "زیباترین پیاده روی در شمال غربی اقیانوس آرام" را به روز کنید:
<figure class="ampstart-image-fullpage-hero m0 relative mb4">
<amp-img width="600" height="900" layout="responsive" src="https://unsplash.it/600/900?image=1003" media="(max-width: 415px)"></amp-img>
<amp-img height="1800" layout="fixed-height" src="https://unsplash.it/1200/1800?image=1003" media="(min-width: 416px)"></amp-img>
<figcaption class="absolute top-0 right-0 bottom-0 left-0">
<header class="p3">
<h1 class="ampstart-fullpage-hero-heading mb3">
<span class="ampstart-fullpage-hero-heading-text">
Most Beautiful Hikes in the Pacific Northwest
</span>
</h1>
<span class="ampstart-image-credit h4">
By <a href="#" role="author" class="text-decoration-none">D.F. Roy</a>,<br> January 14, 2017
</span>
</header>
<footer class="absolute left-0 right-0 bottom-0">
<a class="ampstart-readmore py3 caps line-height-2 text-decoration-none center block h5" href="#content">Read more</a>
</footer>
</figcaption>
</figure>
حالا بیایید نگاهی به صفحه بیندازیم:
خلاصه
- شما یک پوسته برای صفحه خود ایجاد کردید، شامل ناوبری پاسخگو و تصویر و عنوان قهرمان.
- درباره الگوهای AMP اطلاعات بیشتری کسب کردید و از اجزای رابط کاربری AMP Start برای جمع آوری سریع پوسته صفحه استفاده کردید.
کد تکمیل شده این بخش را می توانید در اینجا پیدا کنید: http://codepen.io/aghassemi/pen/RpRdzV
5. محتوای واکنشگرا اضافه کنید
در این بخش، تصاویر، ویدئوها، جاسازیها و مقداری متن را به صفحه خود اضافه میکنیم.
بیایید یک عنصر main
اضافه کنیم که محتوای صفحه را میزبانی کند. ما آن را به انتهای body:
<main id="content">
</main>
عنوان و پاراگراف را اضافه کنید
موارد زیر را به داخل main
اضافه کنید:
<h2 class="px3 pt2 mb2">Photo Gallery</h2>
<p class="ampstart-dropcap mb4 px3">Vivamus viverra augue libero, vitae dapibus lectus accumsan eget. Pellentesque eget ipsum purus. Maecenas leo odio, ornare nec ex id, suscipit porta ipsum. Ut fringilla semper cursus.</p>
از آنجایی که AMP فقط HTML است، هیچ چیز خاصی در مورد این کد به جز نام کلاس های CSS وجود ندارد. px3
، mb2
و ampstart-dropcap
چیست؟ آنها اهل کجا هستند؟
این کلاس ها بخشی از AMP HTML نیستند. قالب های AMP Start از Basscss برای ارائه یک جعبه ابزار CSS سطح پایین و اضافه کردن کلاس های خاص به AMP Start استفاده می کنند.
در این قطعه، px3
و mb2
توسط Basscss تعریف شده و به ترتیب به padding-left-right و margin-bottom تبدیل می شوند. ampstart-dropcap
توسط AMP Start ارائه می شود و حرف اول یک پاراگراف را بزرگتر می کند.
می توانید مستندات این کلاس های CSS از پیش تعریف شده را در http://basscss.com/ و https://ampstart.com/components بیابید.
بیایید ببینیم صفحه اکنون چگونه به نظر می رسد:
یک تصویر اضافه کنید
ساخت صفحات ریسپانسیو در AMP آسان است. در بسیاری از موارد، پاسخگو کردن یک جزء AMP به سادگی افزودن یک ویژگی layout="responsive"
است. مشابه تگ img
HTML، amp-img
از srcset
نیز پشتیبانی می کند تا تصاویر مختلف را برای عرض و تراکم پیکسل های مختلف مشخص کند.
یک amp-img
به main
اضافه کنید:
<amp-img
layout="responsive" width="1080" height="720"
srcset="https://unsplash.it/1080/720?image=1043 1080w, https://unsplash.it/720/480?image=1043 720w"
alt="Photo of mountains and trees landscape">
</amp-img>
با این کد، با مشخص کردن layout="responsive"
و ارائه width
و height.
چرا هنگام استفاده از طرحبندی واکنشگرا باید عرض و ارتفاع را مشخص کنم؟
دو دلیل:
- AMP از عرض و ارتفاع برای محاسبه نسبت ابعاد و حفظ ارتفاع صحیح با تغییر عرض و متناسب با ظرف اصلی خود استفاده می کند.
- AMP برای اطمینان از تجربه کاربری خوب (بدون جهش در صفحه) و تعیین اندازه و موقعیت هر عنصر برای چیدمان صفحه قبل از دانلود منابع، اندازه ایستا را برای همه عناصر اعمال می کند.
حالا بیایید نگاهی به صفحه بیندازیم:
یک ویدیوی پخش خودکار اضافه کنید
AMP از بسیاری از پخش کننده های ویدیو مانند YouTube و Vimeo پشتیبانی می کند. AMP نسخه خاص خود را از عنصر video
HTML5 در زیر مؤلفه توسعه یافته amp-video
دارد. برخی از این پخشکنندههای ویدیو، از جمله amp-video
و amp-youtube
از پخش خودکار بیصدا در تلفن همراه نیز پشتیبانی میکنند.
مشابه amp-img
، amp-video
می تواند با اضافه کردن layout="responsive"
بیایید یک ویدیوی پخش خودکار به صفحه خود اضافه کنیم.
یک پاراگراف دیگر و عنصر amp-video
زیر را به main:
<p class="my2 px3">Vivamus viverra augue libero, vitae dapibus lectus accumsan eget. Pellentesque eget ipsum purus. Maecenas leo odio, ornare nec ex id, suscipit porta ipsum. Ut fringilla semper cursus.</p>
<amp-video
layout="responsive" width="1280" height="720"
autoplay controls loop
src="https://storage.googleapis.com/ampconf-76504.appspot.com/Bullfinch%20-%202797.mp4">
</amp-video>
بیا یک نگاهی بیندازیم:
یک جاسازی اضافه کنید
AMP برای بسیاری از جاسازیهای شخص ثالث مانند توییتر و اینستاگرام ، مؤلفههای توسعهیافته دارد. برای جاسازیهایی که فاقد مؤلفه AMP هستند، همیشه amp-iframe وجود دارد.
بیایید یک جاسازی اینستاگرام به صفحه خود اضافه کنیم.
برخلاف amp-img
و amp-video
، amp-instagram
یک جزء داخلی نیست. تگ اسکریپت import برای آن باید به صراحت در head
صفحه AMP گنجانده شود تا بتوان از مؤلفه استفاده کرد.
دیگ بخار AMP Start که ما استفاده می کنیم شامل چندین تگ اسکریپت وارداتی است. آنها را در ابتدای تگ head
جستجو کنید و اطمینان حاصل کنید که خط اسکریپت import زیر گنجانده شده است:
<script custom-element="amp-instagram" src="https://cdn.ampproject.org/v0/amp-instagram-0.1.js" async></script>
یک پاراگراف دیگر و عنصر amp-instagram
زیر را به main:
<p class="my2 px3">Vivamus viverra augue libero, vitae dapibus lectus accumsan eget. Pellentesque eget ipsum purus. Maecenas leo odio, ornare nec ex id, suscipit porta ipsum. Ut fringilla semper cursus.</p>
<amp-instagram
layout="responsive" width="566" height="708"
data-shortcode="BJ_sPxzAGyg">
</amp-instagram>
بیا یک نگاهی بیندازیم:
احتمالاً فعلاً این محتوا کافی است.
خلاصه
- شما در مورد اجزای پاسخگو در AMP یاد گرفتید.
- شما انواع مختلفی از محتوای رسانه ای و متنی را اضافه کردید.
کد تکمیل شده این بخش را می توانید در اینجا پیدا کنید: http://codepen.io/aghassemi/pen/OpXGoa
6. تعامل را اضافه کنید
ما تاکنون فقط محتوای ثابت برای صفحه خود ایجاد کرده ایم. در این بخش، یک گالری عکس تعاملی با استفاده از اجزایی مانند چرخ فلک، لایت باکس و اقدامات AMP ایجاد می کنیم.
اگرچه AMP از جاوا اسکریپت سفارشی پشتیبانی نمی کند، اما هنوز چندین بلوک ساختمانی را برای دریافت و مدیریت اقدامات کاربر در معرض نمایش قرار می دهد.
یک چرخ فلک عکس اضافه کنید
دیدن هر تصویر برای صفحه AMP متمرکز بر عکس ما در صفحه، تجربه کاربری عالی ایجاد نمی کند. خوشبختانه، ما می توانیم از آمپر چرخ و فلک برای ایجاد اسلایدهای افقی قابل کشیدن از عکس ها استفاده کنیم.
ابتدا، بیایید مطمئن شویم که تگ اسکریپت برای amp-carousel
در head
گنجانده شده است:
<script custom-element="amp-carousel" src="https://cdn.ampproject.org/v0/amp-carousel-0.1.js" async></script>
حالا بیایید یک amp-carousel
پاسخگو از نوع slides
با چندین تصویر به main:
<p class="my2 px3">Vivamus viverra augue libero, vitae dapibus lectus accumsan eget. Pellentesque eget ipsum purus. Maecenas leo odio, ornare nec ex id, suscipit porta ipsum. Ut fringilla semper cursus.</p>
<amp-carousel
layout="responsive" width="1080" height="720"
type="slides">
<amp-img src="https://unsplash.it/1080/720?image=1037" layout="fill"></amp-img>
<amp-img src="https://unsplash.it/1080/720?image=1038" layout="fill"></amp-img>
<amp-img src="https://unsplash.it/1080/720?image=1039" layout="fill"></amp-img>
<amp-img src="https://unsplash.it/1080/720?image=1040" layout="fill"></amp-img>
<amp-img src="https://unsplash.it/1080/720?image=1041" layout="fill"></amp-img>
<amp-img src="https://unsplash.it/1080/720?image=1042" layout="fill"></amp-img>
<amp-img src="https://unsplash.it/1080/720?image=1043" layout="fill"></amp-img>
<amp-img src="https://unsplash.it/1080/720?image=1044" layout="fill"></amp-img>
</amp-carousel>
type="slides"
تضمین می کند که تنها یک تصویر در یک زمان قابل مشاهده است و به کاربران اجازه می دهد تا از میان آنها بکشند.
برای تصاویر داخل چرخ فلک، از layout="fill"
استفاده می کنیم، زیرا چرخ فلک اسلاید همیشه اندازه خود را با عنصر فرزند پر می کند، بنابراین نیازی به تعیین طرح متفاوتی که به عرض و ارتفاع نیاز دارد نیست.
بیایید آن را امتحان کنیم و ببینیم چگونه به نظر می رسد:
یک چرخ فلک تصاویر کوچک اضافه کنید
حالا بیایید یک محفظه با قابلیت اسکرول افقی برای تصاویر کوچک این تصاویر اضافه کنیم. ما دوباره از <amp-carousel>
استفاده خواهیم کرد، اما بدون type="slides"
و با یک طرح با ارتفاع ثابت.
بعد از عنصر amp-carousel
قبلی، موارد زیر را اضافه کنید.
<amp-carousel layout="fixed-height" height="78" class="mt1">
<amp-img src="https://unsplash.it/108/72?image=1037" layout="fixed" width="108" height="72"></amp-img>
<amp-img src="https://unsplash.it/108/72?image=1038" layout="fixed" width="108" height="72"></amp-img>
<amp-img src="https://unsplash.it/108/72?image=1039" layout="fixed" width="108" height="72"></amp-img>
<amp-img src="https://unsplash.it/108/72?image=1040" layout="fixed" width="108" height="72"></amp-img>
<amp-img src="https://unsplash.it/108/72?image=1041" layout="fixed" width="108" height="72"></amp-img>
<amp-img src="https://unsplash.it/108/72?image=1042" layout="fixed" width="108" height="72"></amp-img>
<amp-img src="https://unsplash.it/108/72?image=1043" layout="fixed" width="108" height="72"></amp-img>
<amp-img src="https://unsplash.it/108/72?image=1044" layout="fixed" width="108" height="72"></amp-img>
</amp-carousel>
توجه داشته باشید که برای تصاویر بندانگشتی ما به سادگی از نسخه های layout="fixed"
و با وضوح پایین همان عکس ها استفاده می کنیم.
بیا یک نگاهی بیندازیم:
وقتی کاربر روی یک تصویر کوچک ضربه میزند، تصویر را تغییر دهید
برای انجام این کار، باید رویدادهایی مانند tap
را به اقداماتی مانند تغییر اسلاید گره بزنیم.
رویداد: میتوانیم از ویژگی on
برای نصب کنترلکنندههای رویداد روی یک عنصر استفاده کنیم و رویداد tap
روی همه عناصر پشتیبانی میشود.
action: amp-carousel
یک goToSlide(index=INTEGER)
را نشان میدهد که میتوانیم آن را از Tap event handler هر تصویر کوچک فراخوانی کنیم.
اکنون که از رویداد و عمل مطلع شدیم، بیایید آنها را با هم گره بزنیم.
ابتدا باید به چرخ فلک اسلایدها یک id
بدهیم تا بتوانیم آن را از Tap event handler روی ریز عکسها ارجاع دهیم.
کد موجود خود را تغییر دهید تا یک ویژگی id
به چرخ فلک اسلایدها اضافه کنید (اول):
<amp-carousel
id="imageSlides"
type="slides"
....
اکنون اجازه دهید کنترل کننده رویداد ( on="tap:imageSlides.goToSlide(index=<slideNumber>)")
" را روی هر تصویر کوچک نصب کنیم:
<amp-img on="tap:imageSlides.goToSlide(index=0)" role="button" tabindex="1" layout="fixed" ...
<amp-img on="tap:imageSlides.goToSlide(index=1)" role="button" tabindex="1" layout="fixed" ...
<amp-img on="tap:imageSlides.goToSlide(index=2)" role="button" tabindex="1" layout="fixed" ...
...
توجه داشته باشید که باید به آن tabindex
نیز بدهیم و role
ARIA را برای دسترسی تنظیم کنیم.
خودشه. اکنون با ضربه زدن روی هر تصویر کوچک، تصویر مربوطه را در داخل چرخ فلک اسلاید نشان می دهد.
وقتی کاربر روی آن ضربه می زند، تصویر کوچک را برجسته کنید
آیا می توانیم این کار را انجام دهیم؟ به نظر می رسد هیچ اقدامی برای تغییر کلاس های CSS برای یک عنصر برای فراخوانی از کنترل کننده رویداد ضربه وجود ندارد. بنابراین چگونه می توانیم تصویر کوچک انتخاب شده را برجسته کنیم؟
<amp-selector>
برای نجات!
آمپر انتخابگر با قطعاتی که تاکنون استفاده کرده ایم متفاوت است. این یک جزء ارائه نیست، زیرا بر طرح بندی صفحه تأثیر نمی گذارد. بلکه یک بلوک ساختمانی است که به صفحه AMP اجازه می دهد بداند کاربر چه گزینه ای را انتخاب کرده است.
کاری که amp-selector
می کند بسیار ساده و در عین حال قدرتمند است:
-
amp-selector
می تواند حاوی هر عنصر دلخواه HTML یا مؤلفه AMP باشد. - هر عنصر
amp-selector
می تواند به یک گزینه تبدیل شود اگر ویژگیoption=<value>
باشد. - هنگامی که کاربر روی عنصری که یک گزینه است ضربه میزند،
amp-selector
فقط یک ویژگیselected
شده را به آن عنصر اضافه میکند (و آن را از سایر عناصر گزینه در حالت تک انتخابی حذف میکند). - می توانید با هدف قرار دادن ویژگی
selected
شده با انتخابگر ویژگی CSS، به عنصر انتخاب شده در CSS سفارشی خود استایل دهید.
بیایید ببینیم که چگونه این به ما کمک می کند تا کار را انجام دهیم.
تگ اسکریپت amp-selector
را به head
اضافه کنید:
<script custom-element="amp-selector" src="https://cdn.ampproject.org/v0/amp-selector-0.1.js" async></script>
- چرخ فلک تصویر کوچک را در یک
amp-selector
کنید - با افزودن ویژگی
option=<value>
، هر تصویر کوچک را به یک گزینه تبدیل کنید. - با افزودن ویژگی
selected
شده، اولین تصویر کوچک را به طور پیش فرض انتخاب کنید.
<amp-selector>
<amp-carousel layout="fixed-height" height="78" class="mt1">
<amp-img option=0 selected on="tap:imageSlides.goToSlide(index=0)" ...
<amp-img option=1 on="tap:imageSlides.goToSlide(index=1)" ...
...
</amp-carousel>
</amp-selector>
اکنون باید یک استایل اضافه کنیم تا تصویر کوچک انتخاب شده را برجسته کنیم.
CSS سفارشی زیر را در <style amp-custom>
بعد از boilerplate CSS کوچک شده از AMP Start اضافه کنید:
<style amp-custom>
...
/* low opacity for non-selected thumbnails */
amp-selector amp-img[option] {
opacity: 0.4;
}
/* normal opacity for the selected thumbnail */
amp-selector amp-img[option][selected] {
opacity: 1;
}
</style>
بیا یک نگاهی بیندازیم:
خوب به نظر می رسد، اما آیا متوجه یک اشکال شدید؟
اگر کاربر چرخ فلک اسلاید را بکشد، تصویر کوچک انتخاب شده برای منعکس کننده آن به روز نمی شود. چگونه می توانیم اسلاید فعلی را در چرخ فلک با تصویر کوچک انتخاب شده متصل کنیم؟
در بخش بعدی، نحوه انجام آن را خواهیم آموخت.
خلاصه
- با انواع چرخ فلک و نحوه استفاده از آنها آشنا شدید.
- از کنشها و رویدادهای AMP برای تغییر اسلاید قابل مشاهده در چرخ فلک تصویر زمانی که کاربر روی یک تصویر کوچک ضربه میزند، استفاده کردید.
- شما در مورد
amp-selector
و نحوه استفاده از آن به عنوان یک بلوک ساختمانی برای اجرای موارد استفاده جالب یاد گرفتید.
کد تکمیل شده این بخش را می توانید در اینجا پیدا کنید: http://codepen.io/aghassemi/pen/gmMJMy
7. تعامل را بهبود بخشید
در این بخش از amp-bind برای بهبود تعامل گالری تصاویر از بخش قبل استفاده خواهیم کرد.
amp-bind
چیست؟
کامپوننت اصلی AMP amp-bind
شما امکان می دهد تعاملی سفارشی با اتصال داده ها و عبارات ایجاد کنید.
amp-bind
دارای سه بخش کلیدی است:
- دولت
- الزام آور
- جهش
State یک متغیر حالت برنامه کاربردی است که شامل هر چیزی از یک مقدار واحد تا یک ساختار داده پیچیده است. همه مؤلفه ها می توانند در این متغیر مشترک بخوانند و بنویسند.
Binding عبارتی است که حالت را به یک ویژگی HTML یا محتوای یک عنصر مرتبط می کند.
جهش عمل تغییر مقدار حالت در نتیجه برخی از اقدامات یا رویدادهای کاربر است.
قدرت amp-bind
زمانی شروع میشود که یک جهش اتفاق میافتد: همه اجزایی که به آن حالت اتصال دارند مطلع میشوند و بهطور خودکار بهروزرسانی میشوند تا حالت جدید را منعکس کنند.
بیایید آن را در عمل ببینیم!
از amp-bind
برای پیاده سازی مجدد گالری تصاویر استفاده کنید
قبلاً از اکشنهای AMP (مثلا goToSlide()
) برای گره زدن چرخ فلک اسلاید کامل با یک رویداد tap
بر روی تصاویر کوچک استفاده میکردیم و amp-selector
برای برجسته کردن تصویر کوچک انتخابشده استفاده میکردیم.
بیایید ببینیم چگونه میتوانیم این کد را با استفاده از رویکرد amp-bind
برای اتصال دادهها دوباره پیادهسازی کنیم.
اما قبل از شروع کدنویسی، بیایید رویکرد خود را طراحی کنیم:
1. وضعیت ما چیست؟
در مورد ما بسیار ساده است، تنها ارزشی که به آن اهمیت می دهیم این است که شماره اسلاید فعلی چقدر است. بنابراین، selectedSlide
وضعیت ما است.
2. تعهدات ما چیست؟
هنگام تغییر selectedSlide
چه چیزی باید تغییر کند؟
-
slide
قابل مشاهده چرخ فلک تمام تصویر:
<amp-carousel [slide]="selectedSlide" ...
- مورد
selected
شده درamp-selector
نیز باید تغییر کند. با این کار مشکلی که در قسمت قبل با آن برخورد کردیم برطرف می شود.
<amp-selector [selected]="selectedSlide" ...
3. جهش های ما چیست؟
چه زمانی باید selectedSlide
تغییر کند؟
- وقتی کاربر با کشیدن انگشت به اسلاید جدید در چرخ فلک کامل تصویر تغییر می کند:
<amp-carousel on="slideChange:AMP.setState({selectedSlide:event.index})" ...
- هنگامی که کاربر یک تصویر کوچک را انتخاب می کند:
<amp-selector on="select:AMP.setState({selectedSlide:event.targetOption})" ...
بیایید از AMP.setState
برای ایجاد جهش استفاده کنیم، به این معنی که دیگر به همه کد on="tap:imageSlides.goToSlide(index=n)"
که در تصویر کوچک داشتیم دیگر نیاز نداریم!
بیایید همه را کنار هم بگذاریم:
تگ اسکریپت را برای amp-bind
به head
اضافه کنید:
<script custom-element="amp-bind" src="https://cdn.ampproject.org/v0/amp-bind-0.1.js" async></script>
کد گالری موجود را با رویکرد جدید جایگزین کنید:
<amp-carousel [slide]="selectedSlide" on="slideChange:AMP.setState({selectedSlide:event.index})" type="slides" id="imageSlides" layout="responsive" width="1080" height="720">
<amp-img src="https://unsplash.it/1080/720?image=1037" layout="fill"></amp-img>
<amp-img src="https://unsplash.it/1080/720?image=1038" layout="fill"></amp-img>
<amp-img src="https://unsplash.it/1080/720?image=1039" layout="fill"></amp-img>
<amp-img src="https://unsplash.it/1080/720?image=1040" layout="fill"></amp-img>
<amp-img src="https://unsplash.it/1080/720?image=1041" layout="fill"></amp-img>
<amp-img src="https://unsplash.it/1080/720?image=1042" layout="fill"></amp-img>
<amp-img src="https://unsplash.it/1080/720?image=1043" layout="fill"></amp-img>
<amp-img src="https://unsplash.it/1080/720?image=1044" layout="fill"></amp-img>
</amp-carousel>
<amp-selector [selected]="selectedSlide" on="select:AMP.setState({selectedSlide:event.targetOption})">
<amp-carousel layout="fixed-height" height="78" class="mt1">
<amp-img option=0 selected src="https://unsplash.it/108/72?image=1037" layout="fixed" width="108" height="72"></amp-img>
<amp-img option=1 src="https://unsplash.it/108/72?image=1038" layout="fixed" width="108" height="72"></amp-img>
<amp-img option=2 src="https://unsplash.it/108/72?image=1039" layout="fixed" width="108" height="72"></amp-img>
<amp-img option=3 src="https://unsplash.it/108/72?image=1040" layout="fixed" width="108" height="72"></amp-img>
<amp-img option=4 src="https://unsplash.it/108/72?image=1041" layout="fixed" width="108" height="72"></amp-img>
<amp-img option=5 src="https://unsplash.it/108/72?image=1042" layout="fixed" width="108" height="72"></amp-img>
<amp-img option=6 src="https://unsplash.it/108/72?image=1043" layout="fixed" width="108" height="72"></amp-img>
<amp-img option=7 src="https://unsplash.it/108/72?image=1044" layout="fixed" width="108" height="72"></amp-img>
</amp-carousel>
</amp-selector>
بیایید آن را آزمایش کنیم. روی یک تصویر کوچک ضربه بزنید، اسلایدهای تصویر تغییر خواهند کرد. اسلایدهای تصویر را بکشید تا تصویر کوچک برجسته شده تغییر کند.
متن را به گالری اضافه کنید
ما قبلاً کار سنگینی را برای تعریف و جهش یک حالت برای اسلاید فعلی خود انجام داده ایم. اکنون میتوانیم به راحتی پیوندهای اضافی برای بهروزرسانی سایر اطلاعات بر اساس تعداد اسلایدهای فعلی ارائه کنیم.
بیایید متن "Image x/of y" را به گالری خود اضافه کنیم:
کد زیر را در بالای عنصر چرخ فلک اسلایدها اضافه کنید:
<div class="px3">Image <span [text]="1*selectedSlide + 1">1</span> of 8</div>
این بار، به جای اتصال به یک ویژگی HTML، با استفاده از [text]=
به متن داخلی یک عنصر متصل میشویم.
بیایید آن را امتحان کنیم:
خلاصه
- شما در مورد
amp-bind
یاد گرفتید. - شما از
amp-bind
برای پیاده سازی نسخه بهبودیافته گالری تصاویر استفاده کردید.
کد تکمیل شده این بخش را می توانید در اینجا پیدا کنید: http://codepen.io/aghassemi/pen/MpeMdL
8. جلوه های بصری زیبا را اضافه کنید
در این بخش از دو ویژگی جدید برای افزودن انیمیشن به صفحه خود استفاده خواهیم کرد.
یک افکت اختلاف منظر به عنوان اضافه کنید
amp-fx-collection افزونهای است که مجموعهای از جلوههای بصری از پیش تعیین شده مانند اختلاف منظر را ارائه میکند که میتوان آن را به راحتی بر روی هر عنصری با ویژگیها فعال کرد.
با افکت اختلاف منظر، زمانی که کاربر صفحه را اسکرول می کند، عنصر بسته به مقدار اختصاص داده شده به ویژگی، سریعتر یا کندتر اسکرول می کند.
افکت اختلاف منظر را می توان با افزودن ویژگی amp-fx="parallax" data-parallax-factor="<a decimal factor>"
به هر عنصر HTML یا AMP فعال کرد.
- مقدار ضریب بزرگتر از 1 باعث می شود وقتی کاربر صفحه را به پایین اسکرول می کند، عنصر سریعتر حرکت کند.
- مقدار عامل کمتر از 1 باعث می شود که وقتی کاربر صفحه را به پایین اسکرول می کند، عنصر اسکرول کندتر می شود.
بیایید اختلاف منظر با ضریب 1.5 را به عنوان صفحه خود اضافه کنیم و ببینیم چگونه به نظر می رسد!
تگ اسکریپت amp-fx-collection
را به head
اضافه کنید:
<script custom-element="amp-fx-collection" src="https://cdn.ampproject.org/v0/amp-fx-collection-0.1.js" async></script>
اکنون عنصر عنوان هدر موجود در کد را پیدا کنید و ویژگی amp-fx="parallax" and data-parallax-factor="1.5"
را به آن اضافه کنید:
<header amp-fx="parallax" data-parallax-factor="1.5" class="p3">
<h1 class="ampstart-fullpage-hero-heading mb3">
<span class="ampstart-fullpage-hero-heading-text">
Most Beautiful Hikes in the Pacific Northwest
</span>
</h1>
<span class="ampstart-image-credit h4">
By <a href="#" role="author" class="text-decoration-none">D.F. Roy</a>,<br> January 14, 2017
</span>
</header>
بیایید نگاهی به نتیجه بیاندازیم:
عنوان اکنون سریعتر از بقیه صفحه اسکرول می شود. سرد!
انیمیشن را به صفحه اضافه کنید
amp-animation قابلیتی است که Web Animations API را به صفحات AMP می آورد.
در این بخش، از amp-animation برای ایجاد یک افکت زوم ظریف برای تصویر جلد استفاده می کنیم.
تگ اسکریپت برای amp-animation را به head
اضافه کنید:
<script custom-element="amp-animation" src="https://cdn.ampproject.org/v0/amp-animation-0.1.js" async></script>
حال باید انیمیشن خود و عنصر هدفی که روی آن اعمال می شود را تعریف کنیم.
انیمیشن ها به صورت JSON در داخل یک تگ amp-animation
سطح بالا تعریف می شوند.
کد زیر را مستقیماً زیر تگ body
باز شده در صفحه خود وارد کنید.
<amp-animation trigger="visibility" layout="nodisplay">
<script type="application/json">
{
"target": "heroimage",
"duration": 30000,
"delay": 0,
"fill": "forwards",
"easing": "ease-out",
"keyframes": {"transform": "scale(1.3)"}
}
</script>
</amp-animation>
این کد انیمیشنی را تعریف می کند که به مدت 30 ثانیه بدون تأخیر اجرا می شود و تصویر را 30 درصد بزرگتر می کند.
ما یک fill
رو به جلو تعریف می کنیم تا پس از پایان انیمیشن، تصویر بزرگنمایی شود. target
id
HTML عنصری است که انیمیشن روی آن اعمال می شود.
بیایید یک id
به عنصر تصویر قهرمان در صفحه خود اضافه کنیم تا amp-animation
بتواند روی آن عمل کند.
- تصویر قهرمان موجود (تصویر با وضوح بالا با
layout="fixed-height"
) را در کد خود پیدا کنید وid="heroimage"
را به تگamp-img
اضافه کنید. - برای سادگی،
media="(min-width: 416px)"
را نیز حذف کنید وamp-img
با وضوح پایین دیگر را نیز حذف کنید تا فعلاً مجبور نباشیم با چندین انیمیشن و جستجوهای رسانه ای در amp-animation سروکار داشته باشیم. .
<figure class="ampstart-image-fullpage-hero m0 relative mb4">
<amp-img id="heroimage" height="1800" layout="fixed-height" src="https://unsplash.it/1200/1800?image=1003"></amp-img>
<figcaption class="absolute top-0 right-0 bottom-0 left-0">
...
همانطور که ممکن است متوجه شده باشید، تغییر مقیاس تصویر باعث سرریز شدن تصویر اصلی می شود، بنابراین باید با پنهان کردن سرریز آن را برطرف کنیم.
قانون CSS زیر را به انتهای <style amp-custom>
موجود اضافه کنید:
.ampstart-image-fullpage-hero {
overflow: hidden;
}
بیایید آن را امتحان کنیم و ببینیم چگونه به نظر می رسد:
نامحسوس!
اما به هر حال می توانستم این کار را با CSS انجام دهم. amp-animation
دارد ؟
در این مورد درست است، اما amp-animation
عملکردهای اضافی را امکان پذیر می کند که نمی توان تنها با CSS انجام داد. به عنوان مثال، انیمیشن را می توان بر اساس دید (و همچنین مکث بر اساس دید) فعال کرد یا می تواند با یک عمل AMP فعال شود. amp-animation
نیز مبتنی بر Web Animations API است که خود دارای ویژگی های بیشتری نسبت به انیمیشن های CSS است، به خصوص در مورد قابلیت ترکیب.
خلاصه
- شما با ایجاد افکت های اختلاف منظر با
amp-fx-collection
آشنا شدید. - شما در مورد
amp-animation
یاد گرفتید.
کد تکمیل شده این بخش را می توانید در اینجا پیدا کنید: http://codepen.io/aghassemi/pen/OpXKzo
9. تبریک می گویم!
شما به تازگی ایجاد یک صفحه AMP زیبا و تعاملی را به پایان رسانده اید.
بیایید با نگاهی دوباره به آنچه امروز به دست آورده اید جشن بگیریم.
این یک لینک به صفحه تمام شده است: http://s.codepen.io/aghassemi/debug/OpXKzo
... و کد نهایی: http://codepen.io/aghassemi/pen/OpXKzo
مجموعه ورودی های CodePen برای این کد لبه را می توانید در اینجا بیابید: https://codepen.io/collection/XzKmNB/
اوه قبل از اینکه بریم...
ما فراموش کردیم که بررسی کنیم صفحه ما در سایر عوامل شکل مانند تبلت در حالت افقی چگونه به نظر می رسد.
اجازه بدید ببینم:
عالی!
روز خوبی داشته باشید.
بعدش چیه
این کد لبه فقط سطح آنچه را که در AMP ممکن است خراش می دهد. منابع و کدهای زیادی برای کمک به شما در ایجاد صفحات AMP شگفت انگیز وجود دارد:
اگر سؤالی دارید یا به مشکلی برخوردید، لطفاً ما را در کانال AMP Slack پیدا کنید یا در GitHub بحث، گزارش اشکال یا درخواست ویژگی ایجاد کنید.