Notice
Recent Posts
Recent Comments
«   2024/12   »
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
Archives
Today
Total
관리 메뉴

SYDev

[Express] 4. View 본문

대딩코딩/웹개발 스터디

[Express] 4. View

시데브 2023. 12. 1. 14:38

Ejs

  • Embedded JavaScript Template
  • 기존의 자바스크립트는 html과 script가 태그로 분리되어 있어 script를 html에 적용하기에 어려움이 있었다.
  • 반면에 ejs는 html의 태그처럼 자바스크립트 내용을 삽입할 수 있다.
  • 이로 인해 페이지를 동적으로 짜는 것이 기존보다 훨씬 수월해진다.
//설치 코드
npm install ejs

 

template의 내용을 views/index.ejs 파일로 옮긴다.

 

 파일명: index.ejs

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <h1>WEB</h1>
    <ol>
        <% for(let topic of topics) { %>
            <li><%= topic.title %></li>
        <% } %>
    </ol>
    <a href="/post/create">create</a>
</body>
</html>

 

 

 파일명: main.js

const express = require('express');
require('dotenv').config();
const mysql = require('mysql2/promise');

const app = express();
const port = 3000;

//view engine: 서버에서 js로 만든 변수를 보내줘서 클라이언트에서 활용할 수 있도록 해주는 엔진
//정적인 HTML을 동적으로 만들어줌
app.set('view engine', 'ejs');  //view engine을 ejs로 설정
app.set('views', 'views');  //경로 설정

const db = mysql.createPool({
    host: process.env.DB_HOST,
    user: process.env.DB_USER,
    password: process.env.DB_PASSWORD,
    database: process.env.DB_NAME
});



app.get('/', async (req, res) => {
    const query = 'SELECT * FROM Topics;';  
    const topics = await db.query(query);

    res.render('index.ejs', {topics: topics[0]});   //렌더링: HTML파일을 받아 브라우저에 제공하는 과정
});

app.listen(port, () => {
    console.log(`Example app listening on port ${port}`);
});

 

>> 코드의 길이가 현저하게 줄어든 것을 확인할 수 있다.

 

 

 

 


참고자료

 

Ejs에 대해

EJS는 Embedded JavaScript Template의 약어로 템플릿 엔진 모듈입니다. 이 글에서는 EJS에 대한 설명과 문법에 대해 설명합니다.

velog.io

 

'대딩코딩 > 웹개발 스터디' 카테고리의 다른 글

[Express] 6. Controller  (0) 2023.12.01
[Express] 5. Model  (0) 2023.12.01
[Express] 3. Template과 DB연결  (1) 2023.12.01
[Express] 2. HelloWorld  (0) 2023.11.30
[Node.js] 20. API와 CreateServer  (0) 2023.11.24