일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- regression
- 해커톤
- 회귀
- 티스토리챌린지
- AI
- 머신러닝
- supervised learning
- Classification
- LLM
- 오블완
- gpt
- ChatGPT
- OpenAI
- 분류
- GPT-4
- LG
- LG Aimers
- deep learning
- 지도학습
- 딥러닝
- Machine Learning
- LG Aimers 4th
- PCA
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}`);
});
>> 코드의 길이가 현저하게 줄어든 것을 확인할 수 있다.
참고자료
'대딩코딩 > 웹개발 스터디' 카테고리의 다른 글
[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 |