Google AMP-소개

Google Accelerated Mobile Pages(Google-AMP)는 amp html을 사용하여 경량 웹 페이지를 구축하도록 특별히 설계된 Google의 새로운 오픈 소스 프로젝트입니다. 이 프로젝트의 주요 목표는 AMP 코드가 제대로 작동하고 스마트 폰 및 태블릿과 같은 가능한 모든 장치에서 빠르게로드되는지 확인하는 것입니다.

AMP는 표준 HTML의 확장입니다. HTML 태그가 거의 변경되지 않았으며 AMP는 사용 제한을 추가했습니다. 이 장에서는 변경된 html 태그와 여기에 추가 된 제한 사항을 나열합니다. 이미지, CSS, js, 양식 제출, 비디오, 오디오 등과 같은 외부 리소스로드를 처리하는 태그가 변경됩니다.

또한 amp-date-picker, amp-facebook, amp-ad, amp-analytics, amp-ad, amp-lightbox 등과 같이 html 페이지에서 직접 사용할 수있는 많은 새로운 기능이 amp에 추가되었습니다. 나머지는 디스플레이 용으로 사용됩니다.

이러한 모든 변경 사항과 새로운 기능을 통해 AMP는 라이브 환경에서 사용할 때 페이지에 더 빠른로드와 더 나은 성능을 제공 할 것을 약속합니다.

모바일에서 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 페이지의 예는 다음과 같습니다.

<!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 페이지에서 따라야 할 일과하지 말아야 할 일을 이해합시다.

필수 태그

아래와 같이 amp 페이지에 포함되어야하는 필수 태그가 있습니다.

  • 아래와 같이 html 태그에 amp 또는 ⚡이 추가되었는지 확인해야합니다.

<html amp>
   OR
<html ⚡>
  • <head> 및 <body> 태그는 html 페이지에 추가되어야합니다.

  • 페이지의 헤드 섹션에 다음 필수 메타 태그를 추가해야합니다. 그렇지 않으면 앰프 유효성 검사에 실패합니다.

<meta charset = "utf-8">
<meta name = "viewport" content = "width=device-width, minimum-scale = 1, initial-scale = 1">
  • rel = "canonical"의 링크가 head 태그 내부에 추가됩니다.

<link rel = "canonical" href = "./regular-html-version.html">
  • 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>
  • amp-boilerplate가있는 Noscript 태그 −

<noscript>
   <style amp-boilerplate>
      body{
         -webkit-animation:none;
         -moz-animation:none;
         -ms-animation:none;
         animation:none
      }
   </style>
</noscript>
  • 아래와 같이 async가 추가 된 amp 스크립트 태그가 매우 중요합니다.

<script async src = "https://cdn.ampproject.org/v0.js"> </script>
  • 페이지에 사용자 정의 CSS를 추가하려는 경우 여기에서 amp 페이지에서 외부 스타일 시트를 호출 할 수 없다는 점에 유의하십시오. 사용자 정의 CSS를 추가하려면 모든 CSS가 표시된대로 여기로 이동해야합니다.

<style amp-custom>
   //all your styles here
</style>
  • 스타일 태그에는 amp-custom 속성이 추가되어 있어야합니다.

AMP 구성 요소 용 스크립트

src 및 type =”text / javascript”인 스크립트는 amp 페이지에서 엄격히 허용되지 않습니다. async 및 amp-components와 관련된 스크립트 태그 만 head 섹션에 추가 할 수 있습니다.

이 섹션은 아래와 같이 앰프 구성 요소에 사용되는 몇 가지 스크립트를 나열합니다

amp-ad

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

amp-iframe

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

스크립트에는로드 할 앰프 구성 요소의 이름이 포함 된 비동기 및 맞춤 요소 속성이 있습니다. Amp는 비동기 및 사용자 지정 요소 속성을 기반으로 스크립트 태그의 유효성을 검사하고 다른 스크립트가로드되는 것을 허용하지 않습니다. 걸립니다type=application/json 아래와 같이 샘플 파일에 추가했습니다.

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

위 스크립트는 필요한 경우 다른 amp- 구성 요소 (예 : amp-analytics)와 함께 사용할 수 있습니다.

HTML 태그

지금까지 amp 페이지에 필요한 필수 태그를 살펴 보았습니다. 이제 우리는 허용 / 비 허용되는 HTML 요소와 이에 부과되는 제한에 대해 논의 할 것입니다.

다음은 허용되거나 허용되지 않는 HTML 태그 목록입니다.

Sr. 아니요 HTML 태그 및 설명
1

img

이 태그는 amp-img로 대체됩니다. AMP 페이지에서는 직접 img 태그를 사용할 수 없습니다.

2

video

amp-video로 대체 됨

audio

amp-audio로 대체

4

iframe

amp-iframe으로 대체 됨

5

object

허용되지 않음

6

embed

허용되지 않음

7

form

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

허용됨

11

P, div, header,footer,section

허용됨

12

button

허용됨

13

a

<a> 태그는 다음 조건에서 허용되며 href는 javascript로 시작하면 안됩니다. 있는 경우 대상 속성 값은 _blank 여야합니다.

14

svg

허용되지 않음

15

meta

허용됨

16

Link

허용됩니다. 그러나 외부 스타일 시트를로드 할 수 없습니다.

17

style

허용됩니다. 여기에는 amp-boilerplate 또는 amp-custom 속성이 있어야합니다.

18

base

허용되지 않음

19

noscript

허용됨

코멘트

조건부 HTML 주석은 허용되지 않습니다. 예를 들면-

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

HTML 이벤트

onclick, onmouseover와 같은 html 페이지에서 사용하는 이벤트는 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-. 게다가, 요구 사항에 따라 클래스 이름을 사용할 수 있습니다.

ID

-amp 또는 i-amp- 접두사가 붙은 html 요소에 대한 ID를 가질 수 없습니다. 게다가, 귀하의 요구 사항에 따라 html 요소에 ID를 사용할 수 있습니다.

연결

AMP 페이지에서는 href에 자바 스크립트를 사용할 수 없습니다.

Example

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

스타일 시트

AMP 페이지에서는 외부 스타일 시트를 사용할 수 없습니다. 내부 페이지에 필요한 스타일을 추가 할 수 있습니다.

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

스타일 태그에는 amp-custom 속성이 추가되었습니다.

@-규칙

다음 @-규칙은 스타일 시트에서 허용됩니다.

  • @ font-face, @keyframes, @media, @page, @ supports. @ import는 허용되지 않습니다. 동일한 지원은 향후 추가 될 예정입니다.

  • @keyframes는 <style에서 사용할 수 있습니다.amp-custom> . @keyframe이 너무 많으면 <styleamp-keyframes> 태그를 지정하고 amp 문서 끝에서이 태그를 호출합니다.

  • 클래스 이름, ID, 태그 이름 및 속성 앞에는 -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

  • Typekit-https://use.typekit.net/kitId.css (그에 따라 kitId 교체)

Note − @ font-face 사용자 정의 글꼴은 amp 페이지에서 허용됩니다.

Example

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

AMP 런타임

앰프 코어 파일이로드되면 앰프 런타임 환경이 결정됩니다.

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

코어 파일은 외부 리소스를로드하고,로드 할시기의 우선 순위를 결정하며, # development = 1이 amp URL에 추가 될 때 amp 문서의 유효성을 검사하는 데 도움이됩니다.

Example

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

브라우저에서 실행될 때 위의 URL은 amp 유효성 검사에 실패하면 오류를 나열하고 오류가 없으면 amp 유효성 검사 성공 메시지를 표시합니다.

AMP 구성 요소

Amp에는 많은 앰프 구성 요소가 추가되었습니다. 기본적으로 리소스로드를 효율적으로 처리하는 데 사용됩니다. 또한 애니메이션, 디스플레이 데이터, 광고 표시, 소셜 위젯 등을 처리하는 구성 요소가 포함되어 있습니다.

AMP에는 두 가지 유형의 구성 요소가 있습니다.

  • Built-in
  • External

Note− <amp-img>는 기본 제공 구성 요소이며 core amp js 파일이 추가 된 경우 사용할 수 있습니다. <amp-ad>, <amp-facebook>, <amp-video> 등과 같은 외부 구성 요소에는 추가 할 구성 요소와 관련된 각각의 js 파일이 필요합니다.

공통 속성

너비, 높이, 레이아웃, 자리 표시 자 및 폴 백과 같은 속성은 사용 가능한 거의 모든 AMP 구성 요소에서 사용할 수 있습니다. 이러한 속성은 AMP 페이지에서 구성 요소의 표시를 결정하므로 모든 AMP 구성 요소에 매우 중요합니다.

AMP에 대해 나열된 위의 모든 기능은이 가이드의 뒷부분에서 자세히 설명합니다.

이 자습서의 모든 예제는 장치 용으로 테스트되었으며 Google Mobile Emulator 모드를 사용합니다. 이제 이에 대해 자세히 알아 보겠습니다.

Google 모바일 에뮬레이터

Google 모바일 에뮬레이터를 사용하려면 Chrome 브라우저를 열고 마우스 오른쪽 버튼을 클릭 한 다음 아래와 같이 개발자 콘솔을 엽니 다.

위와 같이 Chrome 용 개발자 도구를 볼 수 있습니다. 브라우저에서 테스트하려는 링크를 누르십시오. 페이지가 데스크탑 모드로 표시되는지 확인하십시오.

장치를 테스트하기 위해 위의 페이지를 얻으려면 아래 그림과 같이 Toggle device toolbar를 클릭하십시오.

단축키 Ctrl + Shift + M을 사용할 수도 있습니다. 그러면 아래와 같이 데스크탑 모드가 장치 모드로 변경됩니다.

장치 목록은 아래와 같이 볼 수 있습니다.

페이지를 테스트 할 장치를 선택할 수 있습니다. 이 튜토리얼의 모든 페이지는 위에 표시된대로 Google 모바일 에뮬레이터에서 테스트되었습니다. Firefox 및 최신 Internet Explorer 브라우저에서도 동일한 기능을 사용할 수 있습니다.