Google AMP - विशेषताएँ

इस अध्याय में amp- घटकों द्वारा उपयोग किए जाने वाले सभी सामान्य विशेषताओं पर चर्चा की जाएगी।

सामान्य विशेषताओं की सूची इस प्रकार है -

  • fallback
  • heights
  • layout
  • media
  • noloading
  • on
  • placeholder
  • sizes
  • चौड़ाई और ऊंचाई

कमबैक विशेषता

फ़ॉलबैक विशेषता का उपयोग ज्यादातर तब किया जाता है जब ब्राउज़र उपयोग किए गए तत्व का समर्थन नहीं करता है या फ़ाइल लोड करने या उपयोग की गई फ़ाइल के साथ त्रुटियां होने की समस्या है।

उदाहरण के लिए, आप एम्पी-वीडियो का उपयोग कर रहे हैं और मीडिया फ़ाइल ब्राउज़र पर समस्या हो रही है इसलिए ऐसे मामलों में हम फ़ॉलबैक विशेषता को निर्दिष्ट कर सकते हैं और एक संदेश प्रदर्शित कर सकते हैं कि मीडिया फ़ाइल ब्राउज़र द्वारा नहीं खेली जा सकती या समर्थित नहीं है, बजाय दिखाने के पृष्ठ पर त्रुटि संदेश।

फ़ालबैक का उपयोग amp- वीडियो पर किया जाता है

<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>

आइए एक उदाहरण का उपयोग करके काम कर रहे ओएस की वापसी को समझते हैं -

उदाहरण

<!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>

उत्पादन

हाइट्स एट्रीब्यूट

यह विशेषता मूल रूप से उत्तरदायी लेआउट के लिए समर्थित है। आप ऊंचाइयों की विशेषता के लिए मीडिया अभिव्यक्ति का उपयोग कर सकते हैं और यह तत्व की ऊंचाई पर लागू होता है। यह प्रतिशत मान भी लेता है, इसलिए ऊंचाई की गणना दी गई प्रतिशत चौड़ाई के आधार पर की जाती है।

उदाहरण

<!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>

उत्पादन

लेआउट विशेषता

एएमपी-लेआउट Google-amp में उपलब्ध महत्वपूर्ण सुविधाओं में से एक है। Amp Layout यह सुनिश्चित करता है कि जब पृष्ठ को कोई झिलमिलाहट या स्क्रॉलिंग समस्या के बिना लोड किया गया हो तो amp घटक ठीक से प्रस्तुत किए गए हों। यह किसी अन्य दूरस्थ संसाधनों जैसे छवियों के लिए http अनुरोध, डेटा कॉल करने से पहले पृष्ठ रेंडरिंग की भी जांच करता है।

Amp द्वारा समर्थित लेआउट की सूची इस प्रकार है -

  • उपस्थित नहीं
  • Container
  • fill
  • fixed
  • fixed-height
  • flex-item
  • intrinsic
  • nodisplay
  • Responsive

आप अध्याय में उसी के बारे में विस्तार से जानेंगे Google AMP − Layout इस ट्यूटोरियल का।

दिखाए गए उदाहरण की मदद से लेआउट के कार्य को "उत्तरदायी" समझें -

उदाहरण

<!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>

उत्पादन

मीडिया अट्रैक्शन

इस विशेषता का उपयोग अधिकांश amp घटकों पर किया जा सकता है। यह एक मीडिया क्वेरी लेता है और यदि मान मेल नहीं खाता है तो घटक प्रदान नहीं किया जाएगा।

आइए एक उदाहरण की मदद से मीडिया विशेषता के कार्य को समझें -

उदाहरण

<!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>

हमने नीचे दिखाए गए के रूप में <amp-img> टैग पर मीडिया विशेषता का उपयोग किया है -

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

ध्यान दें कि यदि स्क्रीन की चौड़ाई 600px से कम है तो छवि प्रदर्शित नहीं की जाएगी। हम उदाहरण का परीक्षण करने के लिए Google एमुलेटर मोबाइल मोड का उपयोग करेंगे।

स्मार्टफोन पर आउटपुट

हमने डिवाइस पर जांच की है कि छवि दिखाई नहीं दे रही है क्योंकि डिवाइस की चौड़ाई 600px से कम है। यदि हम एक टैबलेट पर जांच करते हैं, तो हमें नीचे दिखाए अनुसार आउटपुट मिलता है -

IPAD पर आउटपुट

नोलडिंग विशेषता

Amp घटक जैसे <amp-img>, <amp-video>, <amp-facebook> वास्तविक सामग्री लोड होने और उपयोगकर्ता को दिखाए जाने से पहले एक लोडिंग संकेतक दिखाता है।

लोडिंग इंडिकेटर को दिखाने से रोकने के लिए, हम निम्न प्रकार से नोलडिंग विशेषता का उपयोग कर सकते हैं -

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

गुण पर

इवेंट हैंडलिंग और amp- घटकों पर क्रियाओं के लिए तत्वों पर ऑन विशेषता का उपयोग किया जाता है। विशेषता पर उपयोग करने के लिए वाक्य रचना इस प्रकार है -

सिंटेक्स -

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

विवरण के लिए पारित कर दिया on विशेषता इस प्रकार हैं -

  • eventName- यह उस ईवेंट का नाम लेता है जो एम्पी-घटक के लिए उपलब्ध है। उदाहरण के लिए, प्रपत्रों के लिए हम सबमिट-सक्सेस, सबमिट-एरर इवेंटनाम का उपयोग कर सकते हैं।

  • elementId- यह उस तत्व की आईडी लेता है जिस पर घटना को कॉल करने की आवश्यकता है। यह उस फॉर्म की आईडी हो सकती है जिसके लिए हम सफलता या त्रुटि के बारे में जानना चाहते हैं।

  • methodName - यह ईवेंट होने पर कॉल की जाने वाली विधि का नाम लेता है।

  • arg=value - यह विधि के लिए दिए गए कुंजी = मान फ़ॉर्म के साथ तर्कों को लेता है।

इस प्रकार कई घटनाओं को ऑन एट्रीब्यूट में पास करना भी संभव है -

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

Note - यदि कई घटनाएँ हैं, तो उन्हें विशेषता पर पास किया जाता है और अर्धविराम (;) का उपयोग करके अलग किया जाता है।

क्रियाएँ विशेषता

क्रियाओं का उपयोग मूल रूप से विशेषता के साथ किया जाता है और वाक्य विन्यास इस प्रकार है -

on = "tab:elementid.hide;"

हम निम्नानुसार कई कार्य कर सकते हैं -

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

Elementid उस तत्व की आईडी है जिस पर कार्रवाई की जानी है।

Amp की कुछ विश्व स्तर पर परिभाषित घटनाएं और क्रियाएं हैं जो किसी भी amp- घटक पर उपयोग की जा सकती हैं और वे हैं tap events और क्रियाएँ हैं hide, show तथा togglevisibility

Note - यदि आप किसी html या amp घटक पर टॉगलविजिबिलिटी को छुपाना / दिखाना या उपयोग करना चाहते हैं, तो आप उपयोग कर सकते हैं on=”tap:elementid.[hide/show/togglevisibility]”

प्लेसहोल्डर एट्रीब्यूट

प्लेसहोल्डर विशेषता का उपयोग किसी भी html तत्व पर किया जा सकता है जैसे कि इनपुट तत्व और इसका उपयोग amp- घटक पर भी किया जा सकता है। प्लेसहोल्डर पहली चीज है जिसे पेज पर दिखाया जाएगा और एक बार सामग्री लोड होने के बाद प्लेसहोल्डर हटा दिया जाता है और है अदृश्य कर दिया।

इनपुट तत्व पर प्लेसहोल्डर

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

Amp- घटक पर प्लेसहोल्डर

<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>

गुण देता है

इसका उपयोग हाइट्स विशेषता की तरह ही किया जाता है। मूल्य एक अभिव्यक्ति है जैसा कि नीचे दिखाया गया है -

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

चौड़ाई और ऊँचाई गुण

उनका उपयोग लगभग सभी html तत्वों और amp घटकों पर किया जाता है। चौड़ाई और ऊंचाई का उपयोग उस स्थान पर एक amp तत्व के स्थान का उल्लेख करने के लिए किया जाता है।

उदाहरण

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