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로 변환합니다.