Google AMP - Atribut

Bab ini akan membahas semua atribut umum yang digunakan oleh komponen-amp.

Daftar atribut umum adalah sebagai berikut -

  • fallback
  • heights
  • layout
  • media
  • noloading
  • on
  • placeholder
  • sizes
  • lebar dan tinggi

atribut fallback

Atribut fallback sebagian besar digunakan saat browser tidak mendukung elemen yang digunakan atau memiliki masalah dengan pemuatan file atau mengalami error dengan file yang digunakan.

Misalnya, Anda menggunakan amp-video dan file media mengalami masalah pada browser sehingga dalam kasus seperti itu kami dapat menentukan atribut fallback dan menampilkan pesan bahwa file media tidak dapat diputar atau tidak didukung oleh browser, alih-alih menampilkan pesan kesalahan di halaman.

Penggantian digunakan pada amp-video

<amp-video controls
   width = "640"
   height = "360"
   layout = "responsive"
   poster = "images/videoposter.png">
   <source src = "video/bunny.webm" type = "video/webm" />
   <source src = "video/samplevideo.mp4" type = "video/mp4" />
   <div fallback>
      <p>This browser does not support the video element.</p>
   </div> 
</amp-video>

Mari kita pahami cara kerja fallback os menggunakan contoh -

Contoh

<!doctype html>
<html amp lang = "en">
   <head>
      <meta charset = "utf-8">
      <script async src = "https://cdn.ampproject.org/v0.js"></script>
      <title>Google AMP - Amp Video</title>
      <link rel = "canonical" href = "      http://example.ampproject.org/article-metadata.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 custom-element = "amp-video" 
         src = "https://cdn.ampproject.org/v0/amp-video-0.1.js">
      </script>
   </head>
   <body>
      <h3>Google AMP - Amp Video</h3>
      <amp-video controls
         width = "640"
         height = "360"
         layout = "responsive"
         poster = "images/videoposter.png">
         <source src = "video/bunny.webm"type="video/webm" />
         <source src = "video/samplevideo.mp4"type = "video/mp4" />
         <div fallback>
            <p>This browser does not support the video element.</p>
         </div>
      </amp-video>
   </body>
</html>

Keluaran

Atribut Ketinggian

Atribut ini pada dasarnya didukung untuk tata letak responsif. Anda dapat menggunakan ekspresi media ke atribut heights dan ini berlaku untuk ketinggian elemen. Ini juga mengambil nilai persen, jadi tingginya dihitung berdasarkan persentase lebar yang diberikan.

Contoh

<!doctype html>
<html amp lang = "en">
   <head>
      <meta charset = "utf-8">
      <script async src = "https://cdn.ampproject.org/v0.js"></script>
      <title>Google AMP - heights attribute</title>
      <link rel = "canonical" href = "http://example.ampproject.org/article-metadata.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>
      
      <style amp-custom>
         amp-img {
            border: 1px solid black;
            border-radius: 4px;
            padding: 5px;
         }
         h1{font-family: "Segoe UI",Arial,sans-serif;font-weight: 400;margin: 10px 0;}
      </style>
   </head>
   <body>
      <h1>Google AMP - heights attribute</h1>
      <amp-img src = "images/christmas1.jpg"
         width = "320" height = "256"
         heights = "(min-width:500px) 200px, 80%">
      </amp-img>
   </body>
</html>

Keluaran

atribut tata letak

AMP-Layout adalah salah satu fitur penting yang tersedia di google-amp. Amp Layout memastikan komponen amp dirender dengan benar saat halaman dimuat tanpa menyebabkan masalah pergantian tampilan atau scrolling. Ini juga memeriksa rendering halaman sebelum sumber daya jarak jauh lainnya seperti permintaan http untuk gambar, panggilan data dilakukan.

Daftar tata letak yang didukung oleh amp adalah sebagai berikut -

  • Tidak hadir
  • Container
  • fill
  • fixed
  • fixed-height
  • flex-item
  • intrinsic
  • nodisplay
  • Responsive

Anda akan belajar secara rinci tentang hal yang sama di bab ini Google AMP − Layout dari tutorial ini.

Mari kita pahami cara kerja layout = "responsive" dengan bantuan contoh seperti yang ditunjukkan -

Contoh

<!doctype html>
<html amp lang = "en">
   <head>
      <meta charset = "utf-8">
      <script async src = "https://cdn.ampproject.org/v0.js"></script>
      <title>Google AMP - Image>/title>
      <link rel = "canonical" href = "      http://example.ampproject.org/article-metadata.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>
      
      <style amp-custom>
         amp-img {
            border: 1px solid black;
            border-radius: 4px;
            padding: 5px;
         }
         displayitem {
            display: inline-block;
            width: 200px;
            height:200px;
            margin: 5px;
         }
         h1{font-family: "Segoe 
         UI",Arial,sans-serif;font-weight: 400;margin: 10px 0;}
      </style>
   </head>
   <body>
      <h1>Google AMP - Layout = responsive Image Example>/h1>
      <div class = "displayitem">
         <amp-img alt = "Beautiful Flower"
            src = "images/flower.jpg"
            width = "246"
            height = "205"
            layout = "responsive">
         </amp-img>
      </div>
   </body>
</html>

Keluaran

Atribut Media

Atribut ini dapat digunakan di sebagian besar komponen amp. Dibutuhkan media query dan jika nilainya tidak cocok, komponen tidak akan dirender.

Mari kita memahami cara kerja atribut media dengan bantuan contoh -

Contoh

<!doctype html>
<html amp lang = "en">
   <head>
      <meta charset = "utf-8">
      <script async src = "https://cdn.ampproject.org/v0.js"></script>
      <title>Google AMP - Image</title>
      <link rel = "canonical" href = " http://example.ampproject.org/article-metadata.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>
      <style amp-custom>
         amp-img {
            border: 1px solid black;
            border-radius: 4px;
            padding: 5px;
         }
         h1{font-family: "Segoe 
         UI",Arial,sans-serif;font-weight: 400;margin: 10px 0;}
      </style>
   </head>
   <body>
      <h1>Google AMP - Media Attribute</h1>
      <div class = "displayitem">
         <amp-img
            media = "(min-width: 600px)"
            src = "images/christmas1.jpg"
            width = "466"
            height = "355"
            layout = "responsive">
         </amp-img>
      </div>
   </body>
</html>

Kami telah menggunakan atribut media pada tag <amp-img> seperti yang ditunjukkan di bawah ini -

<amp-img
   media = "(min-width: 600px)"
   src = "images/christmas1.jpg"
   width = "466"
   height = "355"
   layout = "responsive">
</amp-img>

Perhatikan bahwa gambar tidak akan ditampilkan jika lebar layar kurang dari 600px. Kami akan menggunakan mode seluler emulator Google untuk menguji contoh.

Output di Smartphone

Kami memeriksa di perangkat gambar tidak terlihat karena lebar perangkat kurang dari 600px. Jika kami memeriksa di tablet, kami mendapatkan output seperti yang ditunjukkan di bawah ini -

Output di iPad

Atribut Noloading

Komponen amp seperti <amp-img>, <amp-video>, <amp-facebook> menunjukkan indikator pemuatan sebelum konten aktual dimuat dan ditampilkan kepada pengguna.

Untuk berhenti menampilkan indikator pemuatan, kita dapat menggunakan atribut noloading sebagai berikut -

<amp-img src = "images/christmas1.jpg"
   noloading
   height = "300"
   width = "250"
   layout = "responsive">
</amp-img>

Tentang Atribut

Atribut on digunakan pada elemen untuk penanganan peristiwa dan tindakan pada amp-components. Sintaks yang digunakan pada atribut adalah sebagai berikut -

Sintaks -

on = "eventName:elementId[.methodName[(arg1 = value, arg2 = value)]]"

Detailnya diteruskan ke on atributnya adalah sebagai berikut -

  • eventName- Ini mengambil nama acara yang tersedia untuk komponen amp. Misalnya, untuk formulir kita bisa menggunakan submit-success, submit-error eventNames.

  • elementId- Ini mengambil id dari elemen tempat kejadian perlu dipanggil. Ini bisa menjadi id formulir yang ingin kita ketahui tentang keberhasilan atau kesalahannya.

  • methodName - Ini mengambil nama metode yang akan dipanggil pada kejadian kejadian.

  • arg=value - Ini mengambil argumen dengan bentuk key = value yang diteruskan ke metode.

Dimungkinkan juga untuk meneruskan beberapa kejadian ke atribut On sebagai berikut -

on = "submit-success:lightbox;submit-error:lightbox1"

Note - Jika ada beberapa peristiwa, peristiwa tersebut diteruskan ke atribut on dan dipisahkan menggunakan titik koma (;).

Atribut Tindakan

Tindakan pada dasarnya digunakan dengan atribut on dan sintaksnya adalah sebagai berikut -

on = "tab:elementid.hide;"

Kami dapat melewati beberapa tindakan sebagai berikut -

on = "tab:elementid.open;tab:elementid.hide;”

Elementid adalah id dari elemen tempat tindakan akan dilakukan.

Amp memiliki beberapa peristiwa dan tindakan yang ditentukan secara global yang dapat digunakan pada komponen amp apa pun dan memang demikian tap events dan tindakannya hide, show dan togglevisibility.

Note - Jika Anda ingin menyembunyikan / menampilkan atau menggunakan togglevisibility pada komponen html atau amp, Anda dapat menggunakan on=”tap:elementid.[hide/show/togglevisibility]”

Atribut Placeholder

Atribut placeholder dapat digunakan pada elemen html apa pun seperti elemen input dan juga dapat digunakan pada komponen amp. Placeholder adalah hal pertama yang akan ditampilkan di halaman dan setelah konten dimuat, placeholder akan dihapus dan dibuat tidak terlihat.

Placeholder pada elemen masukan

<input type = "text" id = "date" name = "date" placeholder = "Start Date">

Placeholder pada amp-component

<amp-anim src = "images/loreal.gif" width = "300" height = "250" layout = "responsive">
   <amp-img placeholder src = "images/flower.jpg" 
   layout = "fill">
   </amp-img>
</amp-anim>

Ukuran Atribut

Ini digunakan seperti atribut ketinggian. Nilainya adalah ekspresi seperti yang ditunjukkan di bawah ini -

<amp-img src = "amp.png"
   width = "400" height = "300"
   layout = "responsive"
   sizes = "(min-width: 250px) 250px, 100vw">
</amp-img>

Atribut Lebar dan Tinggi

Mereka digunakan di hampir semua elemen html dan komponen amp. Lebar dan tinggi digunakan untuk menyebutkan ruang yang ditempati elemen amp di halaman.

Contoh

<amp-img src = "amp.png"
   width = "400" height = "300"
   layout = "responsive">
</amp-img>