그럼에도 불구하고

👨‍💻

[Png] 동적 콘텐츠 출력 본문

Node.js/Template engines

[Png] 동적 콘텐츠 출력

zenghyun 2023. 2. 8. 22:17

Pug를 이용하여 동적 콘텐츠를 출력해 보자

 

 

 

참고: https://despiteallthat.tistory.com/152

 

[Node.js] pug에 대해 알아보자

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

despiteallthat.tistory.com

 

 

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