수업 시간에 배운 Express를 이용해 CRUD를 구현하는 미니 프로젝트이다.
22.12.26 ~ 22.12.30
Front-End
Back-End
필수 구현 기능
- 메인 페이지 슬라이드
- 회원 가입 기능
- 로그인 기능
- 게시판
- 유저 정보 수정
선택 사항
- 관리자 페이지
- 회원 수정 및 게시글 수정
페이지 디자인은 프로젝트가 시작하기 전 주말에 개인적으로 만들었다.
프로젝트가 시작됬을 때 아무것도 없는 백지 상태에서 페이지를 만들기는 힘들 것 같아서 만들어 보았다.
프로젝트 페이지 디자인
데이터 베이스는 위와 같이 설계하였다.
board의 idx와 reply의 postingNum은 외래키를 이용해 board 게시물이 삭제되면 reply도 삭제되도록 설계하였다.
DB 설계
프로젝트를 하면서 어려웠던 부분은 메인 페이지의 무한 슬라이드 부분과 회원 수정 페이지의 값의 변화에 따라 메시지를 보여주는 부분이었다.
무한 슬라이드 부분은 머리로는 이해가 됬는데 코드가 잘 안쳐졌다.
그리고 저 부분이 오타가 나서 트랜지션 효과가 계속 안먹었는데 결국 프로젝트 막바지에 찾아서 해결 할 수 있었다.
회원 수정 페이지에서는 입력한 값이 변했다는 걸 체크하기 위해 처음에는 blur 이벤트
를 이용했다.
blur 이벤트
를 input 박스에 주고 input 박스에서 focus가 나가면 체크하도록 구현했었는데 뭔가 부자연스럽다는 느낌이 들었다.
그래서 실시간으로 체크할 수 있는 방법을 찾아보다 input 이벤트
와 change 이벤트
를 알게되었다.
input 태그에서 input 이벤트
는 사용자가 입력을 할 때 발동이 되고 change 이벤트
는 요소의 값이 변했을 때 발동이 된다.
input 이벤트
와 change 이벤트
를 활용해서 회원 정보를 수정할 때 값을 체크 하도록 했더니 조금 더 자연스럽게 수정 사항을 체크할 수 있었다.
const reg = {
id: [/^[a-zA-Z0-9]{4,12}$/, `**ID는 4~12자의 영문 대소문자와 숫자로만 입력하여 주세요.`],
pw: [/^(?=.*[a-z])(?=.*\d)[a-zA-Z\d]{5,}$/, `**5글자 이상 소문자,숫자를 포함해주세요.`],
rpw: [/^(?=.*[a-z])(?=.*\d)[a-zA-Z\d]{5,}$/, `**5글자 이상 소문자,숫자를 포함해주세요.`],
userName: [/^[a-zA-Z가-힣]{1,25}$/, `**이름은 최대 25자 영문 한글로만 입력이 가능합니다.`],
nickName: [/^[a-zA-Z0-9가-힣]{2,25}$/, `**닉네임는 2~25자의 영문 대소문자와 숫자, 한글로만 입력하여 주세요.`],
userBirthyy: [/^[0-9]{4,4}$/, `**연도는 4글자로 입력 해주세요.`],
userBirthdd: [/^[0-9]{2,2}$/, `*일자는 2글자로 입력 해주세요.`],
userPhone: [/^[0-9]{3,3}$/, `**3글자숫자로 입력 가능합니다.`],
userPhoneMiddle: [/^[0-9]{3,4}$/, `**3,4글자숫자로 입력 해주세요.`],
userPhoneLast: [/^[0-9]{3,4}$/, `**3,4글자숫자로 입력 해주세요.`],
userCall: [/^[0-9]{3,3}$/, `**3글자숫자로 입력 가능합니다.`],
userCallMiddle: [/^[0-9]{3,4}$/, `**3,4글자숫자로 입력 해주세요.`],
userCallLast: [/^[0-9]{3,4}$/, `**3,4글자숫자로 입력 해주세요.`],
};
const message = {
blank: `**값을 입력해 주세요.`,
duplicate: `중복체크를 해주세요`,
idEngNum: `**ID는 4~12자의 영문 대소문자와 숫자로만 입력하여 주세요.`,
pwLenght: `**5글자 이상 소문자,숫자를 포함해주세요.`,
difPw: `**비밀번호 값이 다릅니다".`,
nameRule: `**이름은 최대 25자 영문 한글로만 입력이 가능합니다.`,
nickNameRule: `**닉네임는 2~25자의 영문 대소문자와 숫자, 한글로만 입력하여 주세요.`,
yearLenght: `**연도는 4글자숫자로 입력 가능합니다.`,
yerrCheck: `**연도를 확인해주세요.`,
dayMax: `*일자는 2글자숫자로 입력 해주세요. ex)1일 -> 01`,
phoneF: `**3글자숫자로 입력 가능합니다.`,
phoneML: `**3,4글자숫자로 입력 해주세요.`,
};
const checkInput = (e) => {
const t = e.target;
const name = t.name;
const value = t.value;
const span = t.dataset.span;
if (value === "") {
spanObj[span].style.color = "red";
spanObj[span].innerHTML = message.blank;
state[t.id] = false;
} else if (!reg[name][0].test(value)) {
spanObj[span].style.color = "red";
spanObj[span].innerHTML = reg[name][1];
state[t.id] = false;
} else {
spanObj[span].innerHTML = "";
state[t.id] = true;
}
};
for (let i = 0; i < input.length; i++) {
input[i].addEventListener("input", checkInput);
}
회원 정보 수정시 입력한 데이터가 형식이 맞는지 체크하는 로직을 구현할 때 겹치는 부분도 생기기도 하고 다른 함수로 만들어서 형식을 체크하기 보다는 하나의 함수에서 체크를 하고 싶어서 형식을 체크하는 정규표현식과 정규표현식에 맞지 않는다면 보여줄 메시지를 객체에 담아서 사용했었다.
이런 형태는 나중에도 사용할 일이 있을 거 같아서 기억을 해둬야 겠다고 생각했다.
디자인적인 부분은 많이 아쉽지만 기능구현은 다 되어서 만족스럽다.
좋은 팀원들을 만나서 좋은 결과를 얻을 수 있었던 것 같다.
다음번 프로젝트에서도 좋은 결과를 얻을 수 있도록 노력해야겠다.