그럼에도 불구하고

👨‍💻

[EJS] EJS에 대해 알아보자 본문

Node.js/Template engines

[EJS] EJS에 대해 알아보자

zenghyun 2023. 2. 9. 23:04

EJS에 대해 알아보자 

 

 

[ 템플릿 엔진 ]

 

웹 페이지 구성 시 가장 기본적으로 쓰이는 마크업 언어인 HTML은 정적인 언어이다. 

정적이기 때문에 주어진 기능만 사용할 수 있으며, 직접 기능을 추가할 수 없다. ( 자바스크립트를 사용하면 가능하다.) 

 

템플릿 엔진은 자바스크립트를 사용하여 HTML을 렌더링 할 수 있게 해 준다. 따라서 기존 HTML과 문법이 다른 부분이 있고, 자바스크립트 문법이 들어가기도 한다. ( 놀랍다. ) 

 

템플릿 엔진에는 대표적으로 퍼그 (Pug), EJS, Handlebars 등이 있다. 

 

https://despiteallthat.tistory.com/152

 

[Png] Pug에 대해 알아보자

오늘은 pug에 대해 알아보자 :) [ 템플릿 엔진 ] 웹 페이지 구성 시 가장 기본적으로 쓰이는 마크업 언어인 HTML은 정적인 언어이다. 정적이기 때문에 주어진 기능만 사용할 수 있으며, 직접 기능을

despiteallthat.tistory.com

 

 

 

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