React

[React/리액트] Modal component 만들기

최슬슬 2022. 10. 6. 08:22

※ 실행화면 ※

One button

Two button

 

※ 사용 기술(언어)※

React, Javascirpt, CSS


 

1. One button

◈ App JSX

import React from "react";
import {useState} from "react";
import "./App.css";
import Modal from "./component/modal";

function App() {
  const [isModal, setIsModal] = useState(false);
  const [info, setInfo] = useState('modal 창 테스트 중……');

  const onClick = () => {
    setIsModal(!isModal)
  }

  return (
    <div className="main">
        <button className="btn" onClick={onClick}>
          Open the modal!
        </button>
        {isModal ? (
            <Modal isModal={isModal} info={info} setIsModal={setIsModal}/>
            ) : null }
    </div>
  );
}

export default App;
  • info useState로 각 모달 창마다 각기 다른 안내문구를 넣을 수 있도록 재사용성을 추가
  • isModa useState가 true일 때, Modal component가 화면에 보이도록 설정

 

 

◈ App CSS

.main{
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

.btn{
  border: none;
  padding: 1rem 1.5rem;
  background-color: #6B8E23;
  color: white;
  font-weight: bold;
  font-size: 1.3rem;
}

 

 

 

◈ Modal JSX

import React from "react";
import './modal.css';

function Modal(props){
    const closeModal = () => {
        if (props.isModal){
            return props.setIsModal(false);
        }
    };

    const content = props.info;

    return (
        <div className="container">
            <div className="modalBody">
                <div className="text">
                    {content.split('\\n').map((text, idx) => (
                        <span key={idx}>
                            {text}
                            <br />
                        </span> ))}
                </div>
                <button className="buttons" onClick={closeModal}>취소</button>
            </div>
        </div>
    );
}

export default Modal;
  • props를 통해 부모(App.js) 컴포넌트에서 선언된 isModal(useState)를 받아와 사용 
  • closeModal에서 isModal이 true인지 확인하고, true일 때, 만약 사용자가 Modal 컴포넌트를 닫고 싶어 하면, isModal를 false로 바꿔. Modal 컴포넌트가 없어지게 함수를 작성 
  • '\n' 기준으로 span tag 안에 있는 문자를 자름 ▶ Modal안에 들어갈 안내문구에 enter가 필요한 경우 '\n'을 사용

 

 

◈ Modal CSS

.container {
    position: fixed;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    background: #C1E7FF;
    width: 250px;
    height: auto;
    white-space: pre-wrap;
    z-index: 70;
}

.modalBody {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
}

.text {
    text-align: center;
    color: black;
    font-size: 1rem;
    height: 80%;
    white-space: pre-line;
    padding: 1.2rem;
}

.buttons {
    width: auto;
    height: auto;
    margin: 1rem;
    color: black;
    border: none;
    padding: 0.5rem;
    background-color: transparent;
}

.buttons:hover{
    background-color: aliceblue;
    border: 1px solid #4599CE;
}

 


 

2. Two button 

 react router dom v6 사용

◈ App JSX

import React from "react";
import { BrowserRouter, Route, Routes } from 'react-router-dom';
import Home from "./component/Home";
import Next from "./component/Next";


function App() {
  return (
      <div className="App">
        <BrowserRouter>
          <Routes>
            <Route path="/" element={<Home />} />
            <Route path="/next" element={<Next />} />
          </Routes>
        </BrowserRouter>
      </div>
  );
}

export default App;
  • 기존 App.jsx에 있던 내용을 Home.jsx에 옮긴 뒤, App.jsx에 route를 추가

 

 

◈ Modal JSX

import React from "react";
import { Link } from "react-router-dom";
import "./modal.css";

function Modal(props){
    const closeModal = () => {
        if (props.isModal){
            return props.setIsModal(false);
        }
    };

    const content = props.info;

    return (
        <div className="container">
            <div className="modalBody">
                <div className="text">
                    {content.split('\\n').map((text, idx) => (
                        <span key={idx}>
                            {text}
                            <br />
                        </span> ))}
                </div>
                <div className="btn-list">
                    <button className="buttons" onClick={closeModal}>취소</button>
                    <Link to = "/next">
                        <button className="buttons">확인</button>
                    </Link>
                </div>
            </div>
        </div>
    );
}

export default Modal;
  • Link를 통해 '확인' 버튼을 누를 경우 '/next' 로 이동시킴

 

 

◈ Modal CSS

.container {
    position: fixed;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    background: #C1E7FF;
    width: 250px;
    height: auto;
    white-space: pre-wrap;
    z-index: 70;
}

.modalBody {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
}

.text {
    text-align: center;
    color: black;
    font-size: 1rem;
    height: 80%;
    white-space: pre-line;
    padding: 1.2rem;
}

.btn-list{
    display: flex;
    flex-direction: row;
    justify-content: space-around;
}

.buttons {
    width: auto;
    height: auto;
    margin: 1rem;
    color: black;
    border: none;
    padding: 0.5rem;
    background-color: transparent;
}

.buttons:hover{
    background-color: aliceblue;
}