Google AMP-Html 페이지에서 앰프 페이지로

이 장에서는 일반 html 페이지를 amp 페이지로 변환하는 방법을 이해합니다. 또한 amp에 대한 페이지의 유효성을 검사하고 마지막에 출력을 확인합니다.

시작하려면 아래에 표시된 일반 html 페이지를 사용합니다.

test.html

<!DOCTYPE html>
<html>
   <head>
      <meta charset = "utf-8">
      <title>Tutorials</title>
      <link href = "style.css" rel = "stylesheet" />
      <meta name = "viewport" content = "width = device-width, initial-scale = 1.0">
      <script src = "js/jquery.js"></script>
   </head>
   <body>
      <header role = "banner">
         <h2>Tutorials</h2>
      </header>
      <h2>Some Important Tutorials List</h2>
      <article>
         <section>
            <img src = "images/tut1.png" width="90%" height = "90%"/>
         </section>
         <section>
            <img src = "images/tut2.png" width="90%" height = "90%"/>
         </section>
         <section>
            <img src = "images/tut3.png" width="90%" height = "90%"/>
         </section>
         <section>
            <img src = "images/tut4.png" width="90%" height = "90%"/>
         </section>
      </article>
      <footer>
         <p>For More tutorials Visit <a href = 
         "https://tutorialspoint.com/">Tutorials Point</a></p>
      </footer>
   </body>
</html>

우리는 style.css를 사용하고 있으며 css 파일의 세부 사항은 여기에 주어진 것과 같습니다.

h1 {color: blue;text-align: center;}
   h2 {text-align: center;}
      img {
         border: 1px solid #ddd;
         border-radius: 4px;
         padding: 5px;
      }
      article {
         text-align: center;
      }
      header{
         width: 100%;
         height: 50px;
         margin: 5px auto;
         border: 1px solid #000000;
         text-align: center;
         background-color: #ccc;
      }
      footer {
         width: 100%;
         height: 35px;
         margin: 5px auto;
         border: 1px solid #000000;
         text-align: center;
         background-color: yellow;
      }

위에 나열된 .html의 jquery.js 파일도 사용했습니다.

이제 로컬에서 test.html을 호스트하고 여기에 제공된 링크에 표시된 출력을 확인하십시오.

http://localhost:8080/googleamp/test.html

이제 위의 test.html 파일을 test_amp.html 파일로 단계별로 변경해 보겠습니다.

먼저 test.html을 test_amp.html로 저장하고 아래 단계를 따라야합니다.

Step 1 − 아래와 같이 헤드 섹션에 앰프 라이브러리를 추가합니다. −

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

예를 들어, test_amp.html에 추가하면 다음과 같습니다.

<head>
   <meta charset = "utf-8">
   <title>Tutorials</title>
   <script async src = "https://cdn.ampproject.org/v0.js">
   </script>
   <link href = "style.css" rel = "stylesheet" />
   <meta name = "viewport" content = "width = device-width, initial-scale = 1.0">
      <script src = "js/jquery.js"></script>
</head>

이제 브라우저에서 test_amp.html 페이지를 실행하고 브라우저 콘솔을 엽니 다. 아래와 같이 콘솔 메시지가 표시됩니다.

html 파일이 유효한 amp인지 확인하려면 아래에 표시된 것처럼 끝에 # development = 1을 html 페이지 URL에 추가하십시오.

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

브라우저와 Google 크롬 콘솔에서 위의 URL을 누르십시오. 앰프 사양의 관점에서 앰프가 유효하지 않다고 생각하는 오류를 나열합니다.

test_amp.html에 대한 오류가 여기에 표시됩니다.

이제 앰프 성공 메시지를받을 때까지 하나씩 수정하겠습니다.

Step 2 − 콘솔에서 다음과 같은 오류를 볼 수 있습니다 −

html 태그에 ⚡ 또는 amp를 추가하여 문제를 해결할 수 있습니다. 다음과 같이 html 태그에 amp를 추가합니다.

<html amp>

Step 3 − 아래와 같이 head 태그에 charset 및 name =”viewport”가 포함 된 메타 태그가 있는지 확인하세요. −

<head>
   <meta charset = "utf-8">
   <meta name = "viewport" content = "width = device-width, initial-scale = 1.0">
</head>

Step 4 − 다음 오류가 여기에 표시됩니다 −

링크 rel = stylesheet에 href가 표시됩니다. 즉, 다음 링크에서 오류가 발생합니다. 이는 amp가 href와 링크를 사용하는 외부 스타일 시트를 페이지 내부에 넣는 것을 허용하지 않기 때문입니다.

<link href = "style.css" rel = "stylesheet" />
We can add the all the css in style.css as follows −
<style amp-custom>
   /*All styles from style.css please add here */
</style>

따라서 style.css에있는 CSS 데이터는 amp-custom 속성을 사용하여 스타일로 추가해야합니다.

<style amp-custom>
   h1 {color: blue;text-align: center;}
   h2 {text-align: center;}
      img {
         border: 1px solid #ddd;
         border-radius: 4px;
         padding: 5px;
      }
      article {
         text-align: center;
      }
      header{
         width: 100%;
         height: 50px;
         margin: 5px auto;
         border: 1px solid #000000;
         text-align: center;
         background-color: #ccc;
      }
      footer {
         width: 100%;
         height: 35px;
         margin: 5px auto;
         border: 1px solid #000000;
         text-align: center;
         background-color: yellow;
      }
</style>

앰프 페이지에 스타일 태그를 추가합니다. 이제 브라우저에서 위의 스타일 태그를 사용하여 동일하게 테스트 해 보겠습니다. 지금까지 test_amp.html에서 변경 한 사항은 다음과 같습니다.

<!DOCTYPE html>
<html amp>
   <head>
      <meta charset = "utf-8">
      <title>Tutorials</title>
      <script async src = "https://cdn.ampproject.org/v0.js">
      </script>
      <meta name = "viewport" content = "width = device-width, initial-scale = 1.0">
      <script src = "js/jquery.js"></script>
      <style amp-custom>
         h1 {color: blue;text-align: center;}
         h2 {text-align: center;}
            img {
               border: 1px solid #ddd;
               border-radius: 4px;
               padding: 5px;
            }
            
            article {
               text-align: center;
            }
            header{
               width: 100%;
               height: 50px;
               margin: 5px auto;
               border: 1px solid #000000;
               text-align: center;
               background-color: #ccc;
            }
            footer {
               width: 100%;
               height: 35px;
               margin: 5px auto;
               border: 1px solid #000000;
               text-align: center;
               background-color: yellow;
            }
      </style>
   </head>
   <body>
      <header role = "banner">
         <h2>Tutorials</h2>
      </header>
      <h2>Some Important Tutorials List</h2>
      <article>
         <section>
            <img src = "images/tut1.png" width = "90%" height = "90%"/>
         </section>
         <section>
            <img src = "images/tut2.png" width = "90%" height = "90%"/>
         </section>
         <section>
            <img src = "images/tut3.png" width = "90%" height = "90%"/>
         </section>
         <section>
            <img src = "images/tut4.png" width="90%" height = "90%"/>
         </section>
      </article>
      <footer>
         <p>For More tutorials Visit <a href = 
         "https://tutorialspoint.com/">Tutorials Point</a></p>
      </footer>
   </body>
</html>

위 페이지의 콘솔에서 출력과 오류를 살펴 보겠습니다. 다음 스크린 샷을 관찰하십시오-

콘솔에 표시되는 오류는 다음과 같습니다.

이제 amp의 일부 오류에 대해 스타일이 제거되었음을 알 수 있습니다. 지금 남은 오류를 수정하겠습니다.

Step 5 − 목록에서 볼 수있는 다음 오류는 다음과 같습니다. −

jquery 파일을 호출하는 스크립트 태그를 추가했습니다. amp 페이지는 페이지에서 맞춤 자바 스크립트를 허용하지 않습니다. 이를 제거하고 사용 가능한 amp-component를 사용해야합니다.

예를 들어 애니메이션이 필요한 경우 amp-animation이 있고 페이지에 Google 애널리틱스 코드를 추가하려는 경우 amp-analytics가 있습니다. 마찬가지로 페이지에 표시 할 광고를 표시하는 amp-ad 구성 요소가 있습니다. 또한 src를 동일한 출처로 지정하고 amp-iframe에서 필요한 경우 맞춤 자바 스크립트를 호출 할 수있는 amp-iframe 구성 요소도 있습니다.

이제 페이지에서 스크립트 태그를 제거하겠습니다.

Step 6 − 표시되는 다음 오류가 여기에 표시됩니다 −

위의 오류는 페이지에서 사용한 이미지 태그를 가리 킵니다. Amp는 페이지 내에서 <img src =””/> 태그를 사용할 수 없습니다. 대신 amp-img 태그를 사용해야합니다.

여기에 표시된대로 <img> 태그를 <amp-img>로 바꾸겠습니다.

<section>
   <amp-img alt = "Beautiful Flower"
      src = "images/tut1.png"
      width = "500"
      height = "160"
      layout = "responsive">
   </amp-img>
</section>
<section>
   <amp-img alt = "Beautiful Flower"
      src = "images/tut2.png"
      width = "500"
      height = "160"
      layout = "responsive">
   </amp-img>
</section>
<section>
   <amp-img alt = "Beautiful Flower"
      src = "images/tut3.png"
      width = "500"
      height = "160"
      layout = "responsive">
   </amp-img>
</section>
<section>
   <amp-img alt = "Beautiful Flower"
      src = "images/tut4.png"
      width = "500"
      height = "160"
      layout = "responsive">
   </amp-img>
</section>

위와 같이 모든 <img> 태그를 <amp-img>로 대체했습니다. 이제 브라우저에서 페이지를 실행하여 출력과 오류를 살펴 보겠습니다.

오류

이제 오류가 줄어들고 있는지 관찰하십시오.

Step 7 − 콘솔에 표시되는 다음 오류는 다음과 같습니다. −

head 섹션에 link rel = canonical 태그를 추가해야합니다. 이것은 필수 태그이며 항상 다음과 같이 헤드에 추가되어야합니다.

<link rel = "canonical" href =
   "http://example.ampproject.org/article-metadata.html">

Step 8 − 누락에 대해 표시되는 다음 오류 noscript tag 여기에 표시된대로 콘솔에서-

다음과 같이 head 섹션에 amp-boilerplate로 묶인 <noscript> 태그를 추가해야합니다.

<noscript>
   <style amp-boilerplate>
      body{
         -webkit-animation:none;
         -moz-animation:none;
         -ms-animation:none;
         animation:none}
   </style>
</noscript>

Step 9 − 표시되는 다음 오류는 다음과 같습니다. −

또 다른 필수 태그는 amp-boilerplate가있는 스타일 태그이며 noscript 태그 앞에 배치해야합니다. amp-boilerplate가있는 스타일 태그는 다음과 같습니다.

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

위의 스타일 태그를 test_amp.html 페이지에 추가합니다.

완료되면 브라우저에서 페이지를 테스트하여 출력과 콘솔을 확인하십시오.

콘솔 세부 정보는 여기에 표시됩니다.

따라서 마침내 모든 오류를 해결했으며 이제 test_amp.html 페이지가 유효한 amp 페이지입니다.

머리글과 바닥 글이 잘 리면서 추가 할 스타일이 몇 가지 있습니다. 추가 한 사용자 지정 스타일에서 동일한 스타일을 업데이트 할 수 있습니다. 따라서 머리글과 바닥 글에서 width : 100 %를 제거했습니다.

다음은 최종 출력입니다.

최종 test_amp.html 파일

<!DOCTYPE html>
<html amp>
   <head>
      <meta charset = "utf-8">
      <title>Tutorials</title>
      <link rel = "canonical" href=
      "http://example.ampproject.org/article-metadata.html">
      <script async src = "https://cdn.ampproject.org/v0.js">
      </script>
      <meta name = "viewport" content = "width = device-width, 
      initial-scale = 1.0">
      
      <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>
         h1 {color: blue;text-align: center;}
         h2 {text-align: center;}
            amp-img {
               border: 1px solid #ddd;
               border-radius: 4px;
               padding: 5px;
            }
            article {
               text-align: center;
            }
            header{
               height: 50px;
               margin: 5px auto;
               border: 1px solid #000000;
               text-align: center;
               background-color: #ccc;
            }
            footer {
               height: 35px;
               margin: 5px auto;
               border: 1px solid #000000;
               text-align: center;
               background-color: yellow;
            }
      </style>
   </head>
   <body>
      <header role = "banner">
         <h2>Tutorials</h2>
      </header>
      <h2>Some Important Tutorials List</h2>
      <article>
         <section>
            <amp-img 
               alt = "Beautiful Flower"
               src = "images/tut1.png"
               width = "500"
               height = "160"
               layout = "responsive">
            </amp-img>
         </section>
         <section>
            <amp-img 
               alt = "Beautiful Flower"
               src = "images/tut2.png"
               width = "500"
               height = "160"
               layout = "responsive">
            </amp-img>
         </section>
         <section>
            <amp-img 
               alt = "Beautiful Flower"
               src = "images/tut3.png"
               width = "500"
               height = "160"
               layout = "responsive">
            </amp-img>
         </section>
         <section>
            <amp-img 
               alt = "Beautiful Flower"
               src = "images/tut4.png"
               width = "500"
               height = "160"
               layout = "responsive">
            </amp-img>
         </section>
      </article>
      <footer>
         <p>For More tutorials Visit <a href = 
         "https://tutorialspoint.com/">
            Tutorials Point</a>
         </p>
      </footer>
   </body>
</html>

따라서 마지막으로 일반 html 파일을 amp로 변환합니다.