문자형 String 작성 방법 3가지

1.      큰 따옴표 → const name = “noonsong”;

2.      작은 따옴표 → const name = ‘noonsong’;

3.      백틱 → const name = `noonsong`;

 

작은 따옴표를 문자열에 사용하고 싶으면 큰 따옴표로 감싸주면 된다.

const message = “I’m an angel.”;

 

또는 역슬레시를 사용한다.

const message2 = ‘I\’m an angel.’;

 

백틱은 문자열 내부의 변수를 표현해줄 때 사용

const message3 = `My name is ${name}`

 

 

문자형과 문자형에 +를 사용하면 두 문자열이 더해진다.

문자형과 숫자형도 +를 사용할 수 있지만 숫자형이 문자형으로 변환됨

 

숫자형 Number

문자열을 숫자로 나누면 NaN(Not a Number)가 뜸

 

null -> 존재하지 않는 값

undefined -> 값이 할당되지 않음

ex) let age; console.log(age); //undefined

 

typeof 연산자 -> 변수의 자료형을 알아낼 수 있음

 

typeof null; 을 하면 “object”가 뜬다.

null 은 객체가 아님. 이건 자바스크립트 초기 버전의 오류이지만 하위 호환성을 유지하기 위해 수정하지 않는다고 함

 

 

↓[코딩앙마] 자바스크립트 기초 강좌 링크

https://www.youtube.com/watch?v=NrVs7ujs6xI 

 

'Study > JavaScript' 카테고리의 다른 글

[JavaScript] 기초 #4 - 형변환  (0) 2021.08.30
[JavaScript] 기초 #3 - alert, prompt, confirm  (0) 2021.08.23
[JavaScript] 기초 #1 - 변수  (0) 2021.08.23
[JavaScript] splice()  (0) 2020.12.21
[JavaScript] 정수 반올림하기  (0) 2020.12.21

 

alert()경고창을 띄움

console.log()로그를 찍는 함수, 쉼표로 원하는 값을 한 번에 찍을 수 있다.

 

 

자바스크립트에서 변수를 선언할 때,

변하지 않는 값은 const, 변할 수 있는 값은 let으로 선언

 

 

let선언은 한 번만, 재사용가능

const절대로 바뀌지 않는 상수, 수정불가

      일단 const로 선언하고 바뀔 시에 let으로 변경하는 습관을 들이는 것이 좋다.

 

 

첫째, 변수는 문자와 숫자, $_만 사용

둘째, 첫 글자는 숫자가 될 수 없다.

셋째, 예악어는 사용할 수 없다.

넷째, 가급적 상수(const 변수)는 대문자로 ex) const MAX_SIZE = 100;

다섯째, 변수명은 읽기 쉽고 이해할 수 있게

ex) let a = 1; //X

let userID = ‘babyAngel’; //O

 

 

 

↓[코딩앙마] 자바스크립트 기초 강좌 링크

https://www.youtube.com/watch?v=P0FY8k916e0 

'Study > JavaScript' 카테고리의 다른 글

[JavaScript] 기초 #4 - 형변환  (0) 2021.08.30
[JavaScript] 기초 #3 - alert, prompt, confirm  (0) 2021.08.23
[JavaScript] 기초 #2 - 자료형  (0) 2021.08.23
[JavaScript] splice()  (0) 2020.12.21
[JavaScript] 정수 반올림하기  (0) 2020.12.21

 

앞서 작성한 글에서 게시글 작성하기를 마쳤으므로 이제 작성한 게시글을 DB에서 불러와 나열해서 보여줘야 한다.

↓ <게시글 작성 구현> 정리글 

https://sungeun97.tistory.com/36?category=1127827 

 

 

먼저 백엔드 파트를 구현하기 위해 server>routes>template.js로 이동하여 다음 코드를 작성한다. 

// template.js

...

router.post("/getTemplates", (req, res) => {
    
    Template.find()
	    .exec((err, templates) => {
        	if(err) {return res.status(400).json({ success: false, err })}
                res.status(200).json({ success: true, templates })
	    })
});

...

 

 

그런 다음 클라이언트 파트를 위해 LandingPage.js로 이동해서 다음 코드를 작성한다. 

주석 처리되어 있는 Filter와 Search 부분에 대한 내용은 다음 게시글에서 정리할 예정이다. 

// LandingPage.js

import React, { useEffect, useState } from 'react';
import axios from 'axios';
import { Col, Card, Row } from 'antd';


const { Meta } = Card;

function LandingPage() {
    const [Templates, setTemplates] = useState([])
    
    useEffect(() => {
        axios.post('/api/template/getTemplates')
            .then(response => {
                if(response.data.success) {
                    setTemplates(response.data.templates)
                } else {
                    alert('Failed to fetch template data')
                }
            })
    }, [])

    
    const renderCards = Templates.map((template, index) => {
        return <Col lg={6} md={8} xs={24} key={index}>
            <Card 
                hoverable={true}
                cover
            > 
                <Meta
                    title={template.title}
                    description={template.writer.name}
                />
            </Card>
        </Col>
    })
    
    return (
        <div style ={{ width: '75%', margin:'3rem auto' }}>
            <div style ={{ textAlign: 'center' }}>
                <h2>모든 속지</h2>
            </div>

            {/* Filter */}
            
            
            {/* Search */}
            
            
            {Templates.length === 0 ?
                <div style ={{ display: 'flex', height:'300px', justifyContent: 'center', alignItems: 'center' }}>
                    <h2>No post yet...</h2>
                </div> :
                <div>
                    <Row gutter={[16, 16]}>
                        {renderCards}
                    </Row>
                </div>
            }
            
            <br /><br />
            
            <div style ={{ display: 'flex', justifyContent: 'center' }}>
            	<button onClick={onLoadMore}>Load More</button>
            </div>
            
        </div>
    )
}

export default LandingPage

 

 

실행시켜보면 작성한 게시글이 Landing Page에 뜨는 것을 확인할 수 있다. 

LandingPage - 게시글 목록

 

 

이제 게시글 작성 시에 등록했던 이미지를 띄우기 위해 client > src > components > utils 폴더에 ImageSlider.js 파일을 생성해서 다음 코드를 작성한다. 

// ImageSlider.js


import React from 'react'
import { Carousel } from 'antd';

function ImageSlider(props) {
    return (
        <div>
            <Carousel autoplay>
                {props.images.map((image, index) => (
                    <div key={index}>
                        <img style={{ width:'100%', height:'150px' }} 
                        src={`http://localhost:5000/${image}`} alt="templateImage" />
                    </div>
                ))}
            </Carousel>
        </div>
    )
}

export default ImageSlider

 

 

그리고 다시 LandingPage.js로 돌아와 다음 코드를 추가한다. 

// LandingPage.js


...

import ImageSlider from '../../utils/ImageSlider';

...

function LandingPage() {
   ...
    
    const renderCards = Templates.map((template, index) => {
        return <Col lg={6} md={8} xs={24} key={index}>
            <Card 
                hoverable={true}
                cover = { <ImageSlider images={template.images} /> }
            > 
                <Meta
                    title={template.title}
                    description={template.writer.name}
                />
            </Card>
        </Col>
    })
    
    ...
}

export default LandingPage

 

 

다시 실행시켜보면 게시글 목록에 이미지 슬라이더가 추가되어 등록한 이미지도 같이 뜨는 것을 확인할 수 있다. 

LandingPage - ImageSlider

 

 

 

마지막으로 이번 포스팅에서는 Load More 버튼 기능으로 마무리하고, 다음 포스팅에서 게시글 필터링 및 검색 기능에 대해 정리할 것이다. 

현재 Load More 버튼 버튼이 보이긴 하지만 onClick 함수를 따로 작성하지 않아 버튼을 클릭해도 아무 기능이 없다. 

 

여기서 하고자하는 것은, Load More 버튼을 눌렀을 때 더 많은 템플릿 게시글들을 불러오는 것이다. 

 

이때, MongoDB의 skip()과 limit() 메소드를 사용한다.

skip()출력할 데이터의 시작 부분을 설정하고, limit() 출력할 데이터의 갯수를 제한한다.

 

skip()과 limit()에 대한 구체적 예를 들어 설명하자면, skip(0)일 경우에는 데이터를 처음부터 가져오게 되고, 만약 이미 데이터를 n개 가져온 상태라면 skip(n)해서 그 뒤의 데이터부터 가져오면 되는 것이다. 

그리고 Load More 버튼을 눌렀을 때 데이터를 4개씩만 가져오고 싶다면 limit(4)로 해서 한 번에 가져올 수 있는 데이터의 양을 4개로 제한할 수 있다. 

 

그렇기 때문에 skip()과 limit()은 Pagination 할 때 많이 사용된다.

 

 

본격적으로 Load More 버튼의 기능을 구현하기 위해 LandingPage.js에 다음 코드를 작성하면 된다.

// LandingPage.js


...

function LandingPage() {
   ...
   
   const [Skip, setSkip] = useState(0) //데이터를 처음부터 가져와야 하기 때문에 initial value = 0
   const [Limit, setLimit] = useState(4) //데이터를 4개씩 가져오기 위해 Limit = 4
   const [PostSize, setPostSize] = useState(0)
   
   ...
   
   useEffect(() => {
        const variables = {
            skip: Skip,
            limit: Limit,
        }

        getTemplates(variables)
    }, [])


    //useEffect에 있던 axios 부분이 거의 동일하게 onLoadMore에서도 사용되기 때문에
    //getTemplates에 axios를 가져와 여러 곳에서 사용할 수 있게 만듦
    const getTemplates = (variables) => { 
        axios.post('/api/template/getTemplates', variables)
            .then(response => {
                if(response.data.success) {
                    setTemplates([...Templates, ...response.data.templates])
                    setPostSize(response.data.postSize)
                } else {
                    alert('Failed to fetch template data')
                }
            })
    }
   
   const onLoadMore = () => {
        let skip = Skip + Limit;

        const variables = {
            skip: skip,
            limit: Limit
        }

        getTemplates(variables)
        setSkip(skip)
    }
   
   ...
   
   return (
        <div style ={{ width: '75%', margin:'3rem auto' }}>
            <div style ={{ textAlign: 'center' }}>
                <h2>모든 속지</h2>
            </div>

            ...
            
            {PostSize >= Limit &&
                <div style ={{ display: 'flex', justifyContent: 'center' }}>
                    <button onClick={onLoadMore}>Load More</button>
                </div>
            }
            
        </div>
    )
   
}

export default LandingPage

 

 

그리고나서 MongoDB에서 게시글을 불러오는 부분을 수정하기 위해 server > routes > template.js 로 이동해서 다음 코드를 작성한다. 

// template.js

...

router.post("/getTemplates", (req, res) => {
    let order = req.body.order ? req.body.order : "desc";
    let sortBy = req.body.sortBy ? req.body.sortBy : -1;
    let limit = req.body.limit ? parseInt(req.body.limit) : 20;
    let skip = parseInt(req.body.skip);
    
    Template.find()
    	.populate("writer")
        .sort([[sortBy, order]])
        .skip(skip)
        .limit(limit)
	.exec((err, templates) => {
	    if(err) {return res.status(400).json({ success: false, err })}
	    res.status(200).json({ success: true, templates, postSize: templates.length })
	})
});

...

 

 

 

이제 게시글을 추가로 작성하여 5개 이상으로 만든 다음, Load More 버튼을 눌러보면 처음에 4개만 보여지던 게시글에서 추가로 더 불러진 것을 확인할 수 있다.

LandingPage - Load More

 

 

+ Recent posts