Google AMP - แบบฟอร์ม

บทนี้จะอธิบายวิธีทำงานกับแบบฟอร์มใน Google AMP

โปรดทราบว่าแท็กแบบฟอร์มยังคงเหมือนกับใน HTML มาตรฐาน AMP ได้เพิ่มข้อ จำกัด พิเศษในการใช้แบบฟอร์มเนื่องจากเราจำเป็นต้องเพิ่มไฟล์ JavaScript รูปแบบแอมป์เพื่อทำงานกับแบบฟอร์ม

สคริปต์สำหรับ amp-form

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

ในการใช้แบบฟอร์มในหน้า AMP เราต้องรวมสคริปต์ด้านบนไว้ในไฟล์. html ไฟล์ JavaScript รูปแบบ amp รองรับhttp และ xmlhttprequestสำหรับการส่งแบบฟอร์ม การใช้คำขอ HTTP เพจจะถูกโหลดซ้ำและด้วยxmlhttprequest มันไม่โหลดหน้าซ้ำทำหน้าที่เหมือนคำขอ ajax

แท็กแบบฟอร์มใน AMP

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-form แสดงไว้ด้านล่าง -

<!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-mustache สำหรับการผูกข้อมูล แบบฟอร์มใช้ action-xhr เช่น 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 และเซิร์ฟเวอร์ apache ในไฟล์ 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

เมื่อคุณรันโค้ดที่แสดงด้านบนคุณจะพบผลลัพธ์ดังที่แสดงด้านล่าง -