Google AMP - परिचय

Google Accelerated Mobile Pages(Google-AMP) Google की नई ओपन सोर्स परियोजना है जिसे विशेष रूप से amp html का उपयोग करके हल्के वजन के वेब पेज बनाने के लिए बनाया गया है। इस परियोजना का मुख्य उद्देश्य यह सुनिश्चित करना है कि एएमपी कोड ठीक काम करता है और स्मार्टफोन और टैबलेट जैसे सभी संभावित उपकरणों पर तेजी से लोड होता है।

एएमपी केवल मानक HTML के लिए एक विस्तार है। कुछ HTML टैग बदल गए हैं और AMP ने उनके उपयोग पर प्रतिबंध जोड़ दिया है। इस अध्याय में, हम उन html टैगों को सूचीबद्ध करेंगे जो बदल दिए गए हैं और उन पर प्रतिबंध जोड़े गए हैं। टैग जो बाहरी संसाधनों को लोड करने से संबंधित हैं, उदाहरण के लिए चित्र, सीएसएस, जेएस, फॉर्म सबमिशन, वीडियो, ऑडियो आदि, बदल दिए जाते हैं।

साथ ही amp में कई नए फीचर्स जोड़े गए हैं, उदाहरण के लिए amp-date-picker, amp-facebook, amp-ad, amp-analytics, amp-ad, amp-lightbox और भी बहुत कुछ जो html पन्नों में सीधे इस्तेमाल किया जा सकता है। बाकी लोग जो प्रदर्शन के लिए होते हैं उनका उपयोग किया जाता है जैसा कि यह है।

इन सभी परिवर्तनों और नई सुविधाओं के साथ, एएमपी लाइव वातावरण में उपयोग किए जाने पर पृष्ठों के लिए तेज़ लोडिंग, बेहतर प्रदर्शन देने का वादा करता है।

जब आप अपने मोबाइल पर Google खोज में कुछ भी खोजते हैं, तो शीर्ष पर Google हिंडोला में जो प्रदर्शन दिखाई देता है, वह अधिकतर amp पृष्ठ नीचे दिखाए गए हैं -

जब आप AMP पेज पर क्लिक करते हैं, तो आपको पता बार में जो URL मिलता है वह इस प्रकार है -

https://www.google.co.in/amp/s/m.timesofindia.com/sports/cricket/india-in-australia/to-hell-with-the-nets-boys-need-rest-ravi-shastri/amp_articleshow/67022458.cms

URL प्रकाशक से सीधे नहीं आ रहा है, लेकिन Google इसे Google सर्वर पर अपनी प्रतिलिपि के लिए इंगित करता है जो एक कैशेड संस्करण है और गैर-amp पृष्ठ की तुलना में सामग्री को तेज़ी से प्रदान करने में मदद करता है। यह केवल उपकरणों या Google एमुलेटर मोड पर होगा।

नमूना Amp पृष्ठ

Amp पेज के लिए एक उदाहरण नीचे दिखाया गया है -

<!doctype html>
<html amp>
   <head>
      <meta charset = "utf-8">
      <title>Amp Sample Page</title>
      <link rel = "canonical" href = "./regular-html-version.html">
      <meta name = "viewport" content = "width = device-width,
         minimum-scale = 1,initial-scale = 1">
      <style amp-custom>
         h1 {color: red}
      </style>
      <script type = application/json>{
         "vars": {
            "uid": "23870",
            "domain": "dummyurl.com",
            "sections": "us",
            "authors": "Hello World"
         }
      }
      </script>
      <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>
      <h1>Amp Sample Page</h1>
      <p>   
         <amp-img src = "imgurl.jpg" width = "300" height = "300" 
            layout = "responsive"></amp-img>
      </p>
      <amp-ad width = "300" height = "250" type = "doubleclick"
         data-slot = "/4119129/no-ad">
         <div fallback>
            <p style = "color:green;font-size:25px;">No ads to Serve!</p>
         </div>
      </amp-ad>
   </body>
</html>

एक एएमपी पेज में क्या करें और क्या न करें

आइए हम कुछ करते हैं और एक प्रोग्रामर को AMP पेज पर चलना है।

अनिवार्य टैग

नीचे दिए गए अनुसार कुछ अनिवार्य टैग amp पृष्ठ में शामिल किए जाने हैं -

  • हमें यह सुनिश्चित करना होगा कि html टैग में amp या that जोड़ा गया है जैसा कि नीचे दिखाया गया है -

<html amp>
   OR
<html ⚡>
  • html पेज में <head> और <body> टैग को जोड़ा जाना चाहिए।

  • पृष्ठ के मुख्य भाग में निम्नलिखित अनिवार्य टैग जोड़े जाने चाहिए; अन्यथा यह amp सत्यापन के लिए विफल हो जाएगा

<meta charset = "utf-8">
<meta name = "viewport" content = "width=device-width, minimum-scale = 1, initial-scale = 1">
  • हेड टैग के अंदर जोड़ने के लिए rel = "canonical" का लिंक

<link rel = "canonical" href = "./regular-html-version.html">
  • Amp- बॉयलरप्लेट के साथ स्टाइल टैग -

<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>
  • Amp- बॉयलरप्लेट के साथ नोस्क्रिप्ट टैग -

<noscript>
   <style amp-boilerplate>
      body{
         -webkit-animation:none;
         -moz-animation:none;
         -ms-animation:none;
         animation:none
      }
   </style>
</noscript>
  • बहुत महत्वपूर्ण amp स्क्रिप्ट टैग async के साथ जोड़ा गया जैसा कि नीचे दिखाया गया है -

<script async src = "https://cdn.ampproject.org/v0.js"> </script>
  • यदि आप पृष्ठ में कस्टम सीएसएस जोड़ना चाहते हैं, तो कृपया यहां एक नोट करें कि हम amp पृष्ठों में बाहरी स्टाइल शीट को नहीं बुला सकते हैं। कस्टम CSS जोड़ने के लिए, आपके सभी CSS को यहाँ दिखाया गया है -

<style amp-custom>
   //all your styles here
</style>
  • स्टाइल टैग में amp- कस्टम विशेषता को जोड़ा जाना चाहिए।

एएमपी घटकों के लिए स्क्रिप्ट

ध्यान दें कि src और type = "text / javascript" वाली स्क्रिप्ट को किसी amp पेज में कड़ाई से अनुमति नहीं है। केवल स्क्रिप्ट टैग जो async और amp- घटकों से संबंधित हैं उन्हें सिर अनुभाग में जोड़ने की अनुमति है।

इस खंड में amp घटकों के लिए उपयोग की जाने वाली कुछ लिपियों को सूचीबद्ध किया गया है -

amp-विज्ञापन

<script async custom-element = "amp-ad" 
   src = "https://cdn.ampproject.org/v0/amp-ad-0.1.js">
</script>

amp-आइफ्रेम

<script async custom-element = "amp-iframe" 
   src = "https://cdn.ampproject.org/v0/amp-iframe-0.1.js">
</script>

ध्यान दें कि स्क्रिप्ट में async और कस्टम-एलिमेंट एट्रिब्यूट है जिसमें एम्पी कंपोनेंट का नाम लोड किया जाना है। Amp, async और कस्टम-एलिमेंट प्रॉपर्टी के आधार पर स्क्रिप्ट टैग को मान्य करता है और किसी अन्य स्क्रिप्ट को लोड करने की अनुमति नहीं देता है। यह लेता हैtype=application/json जो हमने नीचे दिखाए अनुसार नमूना फ़ाइल में जोड़ा है

<type = application/json>
{
   "vars": {
      "uid": "23870",
      "domain": "dummyurl.com",
      "sections": "us",
      "authors": "Hello World"
   }
}
</script>

उपरोक्त स्क्रिप्ट का उपयोग अन्य amp- घटकों के साथ किया जा सकता है यदि आवश्यक हो, उदाहरण के लिए amp-विश्लेषिकी के लिए।

एचटीएमएल टैग

अब तक हमने amp पेज में आवश्यक टैगों को देखा है। अब हम उन HTML तत्वों के बारे में चर्चा करेंगे जिनकी अनुमति / अनुमति नहीं है और उन पर लगाए गए प्रतिबंध हैं।

यहाँ HTML टैग्स की सूची दी गई है जिनकी अनुमति है / अनुमति नहीं है -

अनु क्रमांक HTML टैग और विवरण
1

img

इस टैग को amp-img से बदल दिया गया है। AMP पेज में डायरेक्ट आईएमजी टैग का उपयोग करने की अनुमति नहीं है

2

video

Amp- वीडियो के साथ प्रतिस्थापित

3

audio

Amp- ऑडियो के साथ प्रतिस्थापित

4

iframe

Amp-iframe के साथ प्रतिस्थापित

5

object

अनुमति नहीं हैं

6

embed

अनुमति नहीं हैं

7

form

<फॉर्म> के रूप में इस्तेमाल किया जा सकता है। हमें AMP पेज में फ़ॉर्म के साथ काम करने के लिए स्क्रिप्ट को जोड़ना होगा।

Example −

<script async custom-element = "amp-form"
   src = "https://cdn.ampproject.org/v0/amp-form-0.1.js">
</script>
8

Input elements

Allowed.<input[type = image]>, 
<input[type = button]>,
<input[type = password]>, 
<input[type = file]> 
are not allowed
9

<fieldset>

की अनुमति

10

<label>

की अनुमति

1 1

P, div, header,footer,section

की अनुमति

12

button

की अनुमति

13

a

<a> टैग को निम्नलिखित शर्त के साथ अनुमति दी जाती है, href जावास्क्रिप्ट के साथ शुरू नहीं होना चाहिए। यदि लक्ष्य विशेषता मौजूद है, तो _blank होना चाहिए।

14

svg

अनुमति नहीं हैं

15

meta

की अनुमति

16

Link

की अनुमति दी। लेकिन बाहरी स्टाइलशीट को लोड करने की अनुमति नहीं देता है।

17

style

की अनुमति दी। इसके लिए amp-boilerplate या amp-custom विशेषता होना आवश्यक है।

18

base

अनुमति नहीं हैं

19

noscript

Allowedd

टिप्पणियाँ

सशर्त HTML टिप्पणियों की अनुमति नहीं है। उदाहरण के लिए -

<!--[if Chrome]>
   This browser is chrome (any version)
<![endif]-->

HTML घटनाएँ

ऐसी घटनाएँ जिनका उपयोग हम html पेजों में करते हैं जैसे कि onclick, onmouseover को AMP पेज में अनुमति नहीं है।

हम निम्नानुसार घटनाओं का उपयोग कर सकते हैं -

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

यहाँ इनपुट तत्व पर प्रयुक्त घटना का एक उदाहरण है -

<input id = "txtname" placeholder = "Type here" 
   on = "inputthrottled:
   AMP.setState({name: event.value})">

उपयोग की गई घटना इनपुट-थ्रॉल्ड है।

कक्षाओं

आप उपसर्ग के साथ अपने पृष्ठों में कक्षाएं नहीं कर सकते -amp- or i-amp-। इसके अलावा, आप अपनी आवश्यकता के अनुसार वर्ग नाम का उपयोग कर सकते हैं।

आईडी

आप अपने html तत्वों को -amp या i-amp- के साथ उपसर्ग नहीं दे सकते। इसके अलावा, आप अपनी आवश्यकता के अनुसार अपने HTML तत्व में आईडी का उपयोग कर सकते हैं।

लिंक

जावास्क्रिप्ट को href करने के लिए amp पृष्ठों में अनुमति नहीं है।

Example

<a href = "javascript:callfunc();">click me</a>

स्टाइल शीट्स

एएमपी पेज में बाहरी स्टाइलशीट की अनुमति नहीं है। पेज के लिए आवश्यक शैलियों को अंदर जोड़ना संभव है -

<style amp-custom>
   //all your styles here
</style>

स्टाइल टैग होना चाहिए amp-custom इसमें विशेषता जोड़ी गई।

@ -rules

स्टाइलशीट में निम्न @ -rules की अनुमति है -

  • @ फ़ॉन्ट-चेहरा, @keyframes, @media, @page, @ समर्थन करता है। @ आयात की अनुमति नहीं दी जाएगी। भविष्य में उसी का समर्थन जोड़ा जाएगा।

  • @keyframes को <style के अंदर उपयोग करने की अनुमति हैamp-custom> । यदि @keyframes के बहुत सारे हैं, तो यह <स्टाइल बनाने के लिए अच्छा होगाamp-keyframes> इस टैग को amp दस्तावेज़ के अंत में टैग करें और कॉल करें।

  • वर्ग के नाम, आईडी, टैग नाम और विशेषताओं के साथ उपसर्ग नहीं होना चाहिए -amp- तथा i-amp- क्योंकि वे आंतरिक रूप से amp कोड में उपयोग किए जाते हैं जो संघर्ष का कारण बन सकता है यदि पृष्ठ पर भी रनटाइम पर परिभाषित किया गया हो।

  • !important प्रॉपर्टी को स्टाइल के अंदर रखने की अनुमति नहीं है क्योंकि amp जब भी आवश्यक हो, नौकरशाही का आकार घटाने वाले तत्व को नियंत्रित करना चाहता है।

मन चाहा वर्ण

कस्टम फ़ॉन्ट के लिए शैलियाँ AMP पृष्ठों में अनुमति दी जाती हैं।

Example

<link rel = "stylesheet"
   href = "https://fonts.googleapis.com/css?family=Tangerine">

फ़ॉन्ट्स को मूल उत्पत्ति के बाद से श्वेत किया जाता है जिसे AMP पृष्ठों के अंदर प्रयोग किया जा सकता है।

  • Fonts.com - https://fast.fonts.net

  • Google फ़ॉन्ट्स - https://fonts.googleapis.com

  • फ़ॉन्ट विस्मयकारी - https://maxcdn.bootstrapcdn.com

  • टाइपेकिट - https://use.typekit.net/kitId.css (तदनुसार किटआईडी बदलें)

Note - @ फोंट-चेहरा कस्टम फोंट amp पृष्ठों में अनुमति दी जाती है।

Example

@font-face {
   font-family: myFirstFont;
   src: url(dummyfont.woff);
}

एएमपी रनटाइम

Amp कोर फ़ाइल लोड होने के बाद Amp रनटाइम वातावरण तय किया जाता है -

<script async src = "https://cdn.ampproject.org/v0.js"></script>

कोर फाइल बाहरी संसाधनों को लोड करने का ख्याल रखती है, उन्हें कब लोड करना है, इसकी प्राथमिकता तय करती है और amp दस्तावेज़ को सत्यापित करने में भी मदद करती है जब # URL में # विकास = 1 जोड़ा जाता है।

Example

http://localhost:8080/googleamp/amppage.html#development=1

ब्राउज़र में निष्पादित होने पर उपरोक्त URL त्रुटियों को सूचीबद्ध करेगा यदि amp सत्यापन के लिए विफल रहा है या amp सत्यापन सफल संदेश प्रदर्शित करता है, यदि कोई त्रुटि नहीं है।

एएमपी अवयव

Amp में बहुत सारे amp- घटक जोड़े गए हैं। वे मूल रूप से एक कुशल तरीके से संसाधन के लोडिंग को संभालने के लिए उपयोग किए जाते हैं। इसमें एनीमेशन, प्रदर्शन डेटा, विज्ञापन प्रदर्शित करने, सामाजिक विजेट आदि का ध्यान रखने के लिए घटक भी हैं।

एएमपी में 2 प्रकार के घटक होते हैं।

  • Built-in
  • External

Note- <amp-img> एक अंतर्निहित घटक है और उपलब्ध है यदि कोर amp js फ़ाइल को जोड़ा गया है। बाहरी घटकों जैसे <amp-ad>, <amp-facebook>, <amp-video> और कई अन्य आवश्यकताओं को जोड़ने के लिए घटक से संबंधित js फ़ाइल की आवश्यकता होती है।

सामान्य गुण

चौड़ाई, ऊंचाई, लेआउट, प्लेसहोल्डर और फॉलबैक जैसे गुण उपलब्ध लगभग सभी एएमपी घटकों के लिए उपलब्ध होंगे। किसी भी एएमपी घटक के लिए ये विशेषताएँ बहुत महत्वपूर्ण हैं क्योंकि यह एएमपी पृष्ठ में घटक का प्रदर्शन तय करता है।

एएमपी के लिए सूचीबद्ध सभी उपरोक्त विशेषताओं को इस ट्यूटोरियल के बाद के अध्यायों में विवरण में चर्चा की गई है।

ध्यान दें कि इस ट्यूटोरियल के सभी उदाहरण उपकरणों के लिए परीक्षण किए गए हैं और Google मोबाइल एमुलेटर मोड का उपयोग करते हैं। आइये अब इसके बारे में विस्तार से जानें।

Google मोबाइल एमुलेटर

Google मोबाइल एमुलेटर का उपयोग करने के लिए, क्रोम ब्राउज़र खोलें, राइट क्लिक करें और नीचे दिखाए अनुसार डेवलपर कंसोल खोलें -

हम क्रोम के लिए डेवलपर टूल देख सकते हैं जैसा कि ऊपर दिखाया गया है। उस लिंक को हिट करें जिसे आप ब्राउज़र में परीक्षण करना चाहते हैं। देखें कि पृष्ठ डेस्कटॉप मोड में प्रदर्शित है।

उपकरणों का परीक्षण करने के लिए उपरोक्त पृष्ठ प्राप्त करने के लिए, नीचे दिखाए अनुसार टॉगल डिवाइस टूलबार पर क्लिक करें -

आप शॉर्टकट कुंजी Ctrl + Shift + M का उपयोग भी कर सकते हैं। यह डेस्कटॉप मोड को डिवाइस मोड में बदल देगा जैसा कि नीचे दिखाया गया है -

नीचे दिखाए गए अनुसार उपकरणों की एक सूची देखी जा सकती है -

आप उस डिवाइस को चुन सकते हैं जिसे आप पृष्ठ का परीक्षण करना चाहते हैं। कृपया ध्यान दें कि इन ट्यूटोरियल के सभी पृष्ठ Google मोबाइल एमुलेटर पर परीक्षण किए गए हैं जैसा कि ऊपर दिखाया गया है। यही सुविधा फ़ायरफ़ॉक्स और हाल के इंटरनेट एक्सप्लोरर ब्राउज़रों के लिए भी उपलब्ध है।