일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- git
- @media
- 코딩테스트
- node.js
- node
- 그럼에도 불구하고
- CSS
- HTML
- react-router-dom
- media query
- react
- 자바
- redux
- 반응형 페이지
- 프론트엔드
- webpack
- github
- cleancode
- 코드업
- TypeScript
- coding
- frontend
- max-width
- JavaScript
- 변수
- JS
- java
- 자바문제풀이
- 그럼에도불구하고
- Servlet
- Today
- Total
그럼에도 불구하고
[EJS] EJS에 대해 알아보자 본문
EJS에 대해 알아보자
[ 템플릿 엔진 ]
웹 페이지 구성 시 가장 기본적으로 쓰이는 마크업 언어인 HTML은 정적인 언어이다.
정적이기 때문에 주어진 기능만 사용할 수 있으며, 직접 기능을 추가할 수 없다. ( 자바스크립트를 사용하면 가능하다.)
템플릿 엔진은 자바스크립트를 사용하여 HTML을 렌더링 할 수 있게 해 준다. 따라서 기존 HTML과 문법이 다른 부분이 있고, 자바스크립트 문법이 들어가기도 한다. ( 놀랍다. )
템플릿 엔진에는 대표적으로 퍼그 (Pug), EJS, Handlebars 등이 있다.
https://despiteallthat.tistory.com/152
[ EJS 설치 ]
npm install ejs --save
EJS는 PUG와 같이 즉시 지원이 되는 템플릿 엔진이기 때문에 Handlebars처럼 엔진을 등록할 필요가 없으며,
app.js에서 view engine을 'ejs'로 선언해 주면 된다.
view engine에 대한 자세한 설명은 아래의 링크를 참고하자 :)
https://despiteallthat.tistory.com/152
[ EJS 사용 ]
EJS는 Pug와 달리 HTML 양식을 그대로 사용할 수 있다.
또한, EJS는 Pug와 달리 extends와 같은 레이아웃을 지원하지는 않지만, 일부 구축 블록들을 재활용할 수 있는 include라는 솔루션을 갖고 있다.
기존 html 파일을 EJS로 변환하는 과정을 보자
shop.html
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 | <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Shop</title> <link rel="stylesheet" href="/css/main.css"> </head> <body> <header class="main-header"> <nav class="main-header__nav"> <ul class="main-header__item-list"> <li class="main-header__item"><a class="active" href="/">Shop</a></li> <li class="main-header__item"><a href="/admin/add-product">Add Product</a></li> </ul> </nav> </header> <main> <h1>My Products</h1> <p>List of all the products...</p> </main> </body> </html> | cs |
add-product.html
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Add Product</title> <link rel="stylesheet" href="/css/product.css"> <link rel="stylesheet" href="/css/forms.css"> <link rel="stylesheet" href="/css/main.css"> </head> <body> <header class="main-header"> <nav class="main-header__nav"> <ul class="main-header__item-list"> <li class="main-header__item"><a href="/">Shop</a></li> <li class="main-header__item"><a class="active" href="/admin/add-product">Add Product</a></li> </ul> </nav> </header> <main> <form class="product-form" action="/admin/add-product" method="POST"> <div class="form-control"> <label for="title">Title</label> <input type="text" name="title" id="title"> </div> <button class="btn" type="submit">Add Product</button> </form> </main> </body> </html> | cs |
404.html
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>404 Error</title> <link rel="stylesheet" href="/css/main.css"> </head> <body> <header class="main-header"> <nav class="main-header__nav"> <ul class="main-header__item-list"> <li class="main-header__item"><a href="/">Shop</as=></li> <li class="main-header__item"><a href="/admin/add-product">Add Product</a></li> </ul> </nav> </header> <h1>Page Not Found</h1> </body> </html> | cs |
위 3개의 html 파일에서 공통된 부분을 분리해 보자
head.ejs
1 2 3 4 5 6 7 8 | <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title><%= pageTitle %></title> <link rel="stylesheet" href="/css/main.css"> | cs |
head.ejs에서는 동적 랜더링을 위해 title를 <%= pageTitle %>과 같이 설정해 줬다.
이는 각각의 js 파일에서 랜더링 할 때 pageTitle를 키로 설정하고 내가 설정하고 싶은 title를 값으로 설정해 주면 된다.
shop.js
admin.js
404.ejs
navigation.ejs
1 2 3 4 5 6 7 8 | <header class="main-header"> <nav class="main-header__nav"> <ul class="main-header__item-list"> <li class="main-header__item"><a href="/" class="<%= path === '/' ? 'active' : '' %>">Shop</a></li> <li class="main-header__item"><a href="/admin/add-product" class="<%= path === '/admin/add-product' ? 'active' : '' %>">Add Product</a></li> </ul> </nav> </header> | cs |
end.ejs
1 2 3 | </body> </html> | cs |
분리한 블록들은 내가 사용할 ejs 파일에서 include를 통해 사용할 수 있다.
<%- include('includes/head.ejs') %>
<%- include('includes/navigation.ejs') %>
<%- include('includes/end.ejs')%>
shop.ejs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 | <%- include('includes/head.ejs') %> <link rel="stylesheet", href="/css/product.css"> </head> <body> <%- include('includes/navigation.ejs') %> <main> <% if(prods.length > 0) { %> <div class="grid"> <% for( let product of prods) { %> <article class="card.product-item"> <header class="card__header"> <h1 class="product__title"><%= product.title %></h1> </header> <div class="card__image"> <img src="", alt="A Book"> </div> <div class="card__content"> <h2 class="product__price">$19.99</h2> <p class="product__description">A very interesting book about so many even more interesting things!</p> <div class="card__actions"> <button class="btn">Add to Cart</button> </div> </div> </article> <% } %> </div> <% } else { %> <h1> No Product Found!</h1> <% } %> </main> <%- include('includes/end.ejs')%> | cs |
add-product.ejs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | <%- include('includes/head.ejs') %> <link rel="stylesheet" href="/css/main.css"> <link rel="stylesheet", href="/css/product.css"> <link rel="stylesheet" href="/css/forms.css"> </head> <body> <%- include('includes/navigation.ejs') %> <main> <form class="product-form" action="/admin/add-product" method="POST"> <div class="form-control"> <label for="title">Title</label> <input type="text" name="title" id="title"> </div> <button class="btn" type="submit">Add Product</button> </form> </main> <%- include('includes/end.ejs') %> | cs |
404.ejs
1 2 3 4 5 6 | <%- include('includes/head.ejs') %> </head> <body> <%- include('includes/navigation.ejs') %> <h1>Page Not Found</h1> <%- include('includes/end.ejs') %> | cs |
'Node.js > Template engines' 카테고리의 다른 글
[Png] Pug layout 만들기 (0) | 2023.02.09 |
---|---|
[Png] 동적 콘텐츠 출력 (0) | 2023.02.08 |
[Png] Pug에 대해 알아보자 (0) | 2023.02.08 |