Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 코딩테스트
- node
- node.js
- cleancode
- JS
- JavaScript
- 코드업
- frontend
- 자바문제풀이
- Servlet
- 자바
- TypeScript
- max-width
- @media
- media query
- 반응형 페이지
- coding
- git
- 그럼에도 불구하고
- HTML
- java
- webpack
- 그럼에도불구하고
- 변수
- CSS
- react
- 프론트엔드
- redux
- react-router-dom
- github
Archives
- Today
- Total
그럼에도 불구하고
[Png] 동적 콘텐츠 출력 본문
Pug를 이용하여 동적 콘텐츠를 출력해 보자
참고: https://despiteallthat.tistory.com/152
shop.png
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 | <!DOCTYPE html> html(lang="ko") head meta(charset="UTF-8") meta(name="viewport", content="width=device-width, initial-scale=1.0") meta(http-equiv="X-UA-Compatible", content="ie=edge") title #{docTitle} link(rel="stylesheet", href="/css/main.css") link(rel="stylesheet", href="/css/product.css") body header.main-header nav.main-header__nav ul.main-header__item-list li.main-header__item a.active(href="/") Shop li.main-header__item a(href="/admin/add-product") Add Product main if prods.length > 0 .grid each product in prods article.card.product-item header.card__header h1.product__title #{product.title} div.card__image img(src="", alt="A Book") div.card__content h2.product__price $19.99 p.product__description A very interesting book about so many even more interesting things! .card__actions button.btn Add to Cart else h1 No Products | cs |
app.js
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 | const path = require('path'); const express = require('express'); const bodyParser = require('body-parser'); const app = express(); app.set('view engine', 'pug'); app.set('views', 'views'); const adminData = require('./routes/admin'); const showRoutes = require('./routes/shop'); app.use(bodyParser.urlencoded({ extended: false })); app.use(express.static(path.join(__dirname, 'public'))); app.use('/admin', adminData.routes); app.use(showRoutes); app.use((req, res, next) => { res.status(404).sendFile(path.join(__dirname, './', 'views', '404.html')); }); app.listen(3000); | cs |
admin.js
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | const path = require('path'); const express = require('express'); const router = express.Router(); const products = []; // /admin/add-product => GET router.get('/add-product', (req, res, next) => { res.sendFile(path.join(__dirname, '../', 'views', 'add-product.html')); }); // /admin/add-product => POST router.post('/add-product', (req, res, next) => { products.push({ title: req.body.title }) res.redirect('/'); }) exports.routes = router; exports.products = products; | cs |
shop.js
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | const path = require('path'); // 코어 모듈 임포트 const express = require('express'); const router = express.Router(); const adminData = require('./admin'); router.get('/', (req, res, next) => { const products = adminData.products; res.render('shop', { prods: products, doTitle: 'Shop' }); }); module.exports = router; | cs |
const products = adminData.products;
res.render('shop', { prods: products, doTitle: 'Shop' });
shop.js에서 doTitle를 'Shop'라고 설정하고
shop.png에서 title를 설정
title #{docTitle}
+ /admin/add-product 페이지에서 받아올 input을 shop.png로 가져옴
아직 Add Product에서 입력을 안 받았기에 No Products
Add Product 페이지에서 First Book라고 입력
Shop 페이지 결과
'Node.js > Template engines' 카테고리의 다른 글
[EJS] EJS에 대해 알아보자 (0) | 2023.02.09 |
---|---|
[Png] Pug layout 만들기 (0) | 2023.02.09 |
[Png] Pug에 대해 알아보자 (0) | 2023.02.08 |
Comments