| 일 | 월 | 화 | 수 | 목 | 금 | 토 | 
|---|---|---|---|---|---|---|
| 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 | 
                            Tags
                            
                        
                          
                          - gpt
 - LG Aimers
 - 분류
 - LG Aimers 4th
 - LG
 - 지도학습
 - LLM
 - 딥러닝
 - OpenAI
 - deep learning
 - Machine Learning
 - 머신러닝
 - AI
 - Classification
 - 티스토리챌린지
 - 회귀
 - 해커톤
 - regression
 - GPT-4
 - PCA
 - supervised learning
 - 오블완
 - ChatGPT
 
                            Archives
                            
                        
                          
                          - Today
 
- Total
 
SYDev
[Express] 4. View 본문
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
728x90
    
    
  반응형
    
    
    
  '대딩코딩 > 웹개발 스터디' 카테고리의 다른 글
| [Express] 6. Controller (1) | 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 |