Google AMP - फ़ॉर्म
यह अध्याय बताता है कि Google AMP में फॉर्म के साथ कैसे काम करें।
ध्यान दें कि टैग के रूप में मानक HTML में ही रहता है। एएमपी ने रूपों के उपयोग पर विशेष प्रतिबंध जोड़ा है जिसके कारण हमें रूपों के साथ काम करने के लिए amp- फॉर्म जावास्क्रिप्ट फ़ाइल को जोड़ना होगा।
Amp- फार्म के लिए स्क्रिप्ट
<script async custom-element = "amp-form"
src = "https://cdn.ampproject.org/v0/ampform-0.1.js"></script>
एएमपी पृष्ठ में रूपों का उपयोग करने के लिए, हमें उपरोक्त स्क्रिप्ट को .html फ़ाइल में शामिल करना होगा। Amp- प्रपत्र जावास्क्रिप्ट फ़ाइल का समर्थन करता हैhttp तथा xmlhttprequestफार्म जमा करने के लिए। HTTP अनुरोध का उपयोग करके पृष्ठ पुनः लोड किया गया है और साथ हैxmlhttprequest यह पृष्ठ को पुनः लोड नहीं करता है जैसे ajax अनुरोध।
एएमपी में फॉर्म टैग
For xmlhttprequest :
<form method = "post" class = "p2" action-xhr = "submitform.php" target = "_top">
//Input fields here
</form>
For http :
<form method = "post" class = "p2" action = "submitform.php" target = "_top">
//Input fields here
</form>
Amp-form विशेष गुण प्रदान करता है अर्थात, submit-error तथा submit-success फ़ॉर्म सबमिट होने पर त्रुटि और सफलता को संभालने के लिए।
Example
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 - Form</title>
<link rel = "canonical" href = "ampform.html">
<meta name = "viewport" conten t = "width = device-width,
minimum-scale = 1,initialscale = 1">
<style amp-boilerplate>
body{
-webkit-animation:
-amp-start 8s steps(1,end) 0s1 normal both;-moz-animation:
-amp-start 8s steps(1,end) 0s 1 normal both;-msanimation:
-amp-start 8s steps(1,end) 0s 1 normal both;animation:
-amp-start 8s steps(1,end) 0s 1 normal both
}
@-webkit-keyframes
-ampstart{from{visibility:hidden}to{visibility:visible}}@-moz-keyframes
-ampstart{from{visibility:hidden}to{visibility:visible}}@-ms-keyframes
-ampstart{from{visibility:hidden}to{visibility:visible}}@-o-keyframes
-ampstart{from{visibility:hidden}to{visibility:visible}}@keyframes
-ampstart{from{visibility:hidden}to{visibility:visible}}
</style>
<noscript>
<style amp-boilerplate>
body{
-webkit-animation:none;
-moz-animation:none;
-msanimation:none;
animation:none
}
</style>
</noscript>
<script async custom-element = "amp-form"
src = "https://cdn.ampproject.org/v0/amp-form-0.1.js">
</script>
<script async custom-template = "amp-mustache"
src = "https://cdn.ampproject.org/v0/amp-mustache-0.2.js">
</script>
<style amp-custom>
form.amp-form-submit-success [submit-success],
form.amp-form-submit-error [submit-error]{
margin-top: 16px;
}
form.amp-form-submit-success [submit-success] {
color: white;
background-color:gray;
}
form.amp-form-submit-error [submit-error] {
color: red;
}
form.amp-form-submit-success.hide-inputs > input {
display: none;
}
</style>
</head>
<body>
<h3>Google AMP - Form</h3>
<form method = "post"
class = "p2"
action-xhr = "submitform.php"
target = "_top">
<p>AMP - Form Example</p>
<div>
<input type = "text" name = "name" placeholder = "Enter
Name" required><br/><br/>
<input type = "email" name = "email"
placeholder = "Enter Email" required>
<br/>
<br/>
</div>
<input type = "submit" value = "Submit">
<div submit-success>
<template type = "amp-mustache">
Form Submitted! Thanks {{name}}.
</template>
</div>
<div submit-error>
<template type = "amp-mustache">
Error! {{name}}, please try again.
</template>
</div>
</form>
</body>
</html>
Output
जब आप ऊपर दिखाए गए कोड को निष्पादित करते हैं, तो आपको नीचे दिखाए अनुसार परिणाम मिलेगा -
अब, विवरण दर्ज करें और सबमिट बटन पर क्लिक करें। प्रदर्शित आउटपुट स्क्रीन इस प्रकार है -
गौर करें कि हमने डेटा-बाइंडिंग के लिए amp-मूंछों का उपयोग किया है। फॉर्म जमा करने के लिए एक्शन-एक्सआर यानी xmlhttprequest का उपयोग कर रहा है। हमने इस्तेमाल किया हैsubmitform.php फ़ाइल जो डेटा को json प्रारूप में लौटाती है।
<form method = "post" class = "p2" action-xhr = "submitform.php"
target = "_top">
</form>
submitform.php
<?php
if(!empty($_POST)){
$domain_url = (isset($_SERVER['HTTPS']) ? "https" : "http") . "://$_SERVER[HTTP_HOST]";
header("Content-type: application/json");
header("AMP-Access-Control-Allow-Source-Origin: " . $domain_url);
header("Access-Control-Expose-Headers: AMP-Access-Control-Allow-Source-Origin");
$myJSON = json_encode($_POST);
echo $myJSON;
}
?>
प्रपत्र को xmlhttprequest का उपयोग करके काम करने के लिए, हमें CORS विनिर्देशन के अनुसार हेडर जोड़ने की आवश्यकता है। Submitform.php में जोड़े गए प्रतिक्रिया शीर्षकों का विवरण नीचे दिखाया गया है -
काम करने के लिए फार्म के लिए, हमें हेडर जोड़ने की आवश्यकता है जैसे कि access-control-expose-headers मूल्य के साथ AMP-Access-Control-Allow-Source-Origin तथा amp-access-controlallow- source-origin -http://localhost:8080।
ध्यान दें कि हम एक php फ़ाइल और अपाचे सर्वर का उपयोग कर रहे हैं। Php फ़ाइल में, हमने आवश्यक हेडर को नीचे दिखाए अनुसार जोड़ा है -
<?php
if(!empty($_POST)){
$domain_url = (isset($_SERVER['HTTPS']) ? "https" : "http") . "://$_SERVER[HTTP_HOST]";
header("Content-type: application/json");
header("AMP-Access-Control-Allow-Source-Origin: " . $domain_url);
header("Access-Control-Expose-Headers: AMP-Access-Control-Allow-Source-Origin");
$myJSON = json_encode($_POST);
echo $myJSON;
}
?
?>
यदि हम सामान्य http अनुरोध का उपयोग करते हैं, तो पृष्ठ नीचे दिखाए अनुसार पुनः लोड हो जाएगा -
Http अनुरोध के लिए हमने निम्नानुसार फॉर्म का उपयोग किया है -
<form method = "GET" class = "p2" action = "submitform.php"
target = "_top">
</form>
Example
बेहतर समझ के लिए निम्नलिखित कोड देखें -
<!doctype html>
<html amp lang = "en">
<head>
<meta charset = "utf-8">
<script async src = "https://cdn.ampproject.org/v0.js"></script>
<title>Google AMP - Form</title>
<link rel = "canonical" href = "ampform.html">
<meta name = "viewport" content = "width = device-width,minimum-scale = 1,initialscale = 1">
<style amp-boilerplate>
body{
-webkit-animation:
-amp-start 8s steps(1,end) 0s1 normal both;-moz-animation:
-amp-start 8s steps(1,end) 0s 1 normal both;-msanimation:
-amp-start 8s steps(1,end) 0s 1 normal both;animation:
-amp-start 8s steps(1,end) 0s 1 normal both
}
@-webkit-keyframes
-ampstart{from{visibility:hidden}to{visibility:visible}}@-moz-keyframes
-ampstart{from{visibility:hidden}to{visibility:visible}}@-ms-keyframes
-ampstart{from{visibility:hidden}to{visibility:visible}}@-o-keyframes
-ampstart{from{visibility:hidden}to{visibility:visible}}@keyframes
-ampstart{from{visibility:hidden}to{visibility:visible}}
</style>
<noscript>
<style amp-boilerplate>
body {
-webkit-animation:none;
-moz-animation:none;
-msanimation:none;
animation:none}
>/style>
</noscript>
<script async custom-element = "amp-form"
src = "https://cdn.ampproject.org/v0/amp-form-0.1.js">
</script>
<script async custom-template = "amp-mustache"
src = "https://cdn.ampproject.org/v0/amp-mustache-0.2.js">
</script>
<style amp-custom>
form.amp-form-submit-success [submit-success],
form.amp-form-submit-error [submit-error]{
margin-top: 16px;
}
form.amp-form-submit-success [submit-success] {
color: white;
background-color:gray;
}
form.amp-form-submit-error [submit-error] {
color: red;
}
form.amp-form-submit-success.hide-inputs >
input {
display: none;
}
</style>
</head>
<body>
<h3>Google AMP - Form</h3>
<form method = "GET" class = "p2" action = "submitform.php" target = "_top">
<p>AMP - Form Example</p>
<div>
<input type = "text" name = "name" placeholder = "Enter Name" required>
<br/>
<br/>
<input type = "email" name = "email" placeholder = "Enter Email" required>
<br/>
<br/>
<div>
<input type = "submit" value = "Submit">
<div submit-success>
<template type = "amp-mustache">
Form Submitted! Thanks {{name}}.
</template>
</div>
<div submit-error>
<template type = "amp-mustache">
Error! {{name}}, please try again.
</template>
</div>
</form>
</body>
</html>
Output
जब आप ऊपर दिखाए गए कोड को निष्पादित करते हैं, तो आपको नीचे दिखाए अनुसार परिणाम मिलेगा -