메인 페이지
메인 페이지는 크게 2개로 나눌 수 있다.
회원정보 파트와 프로젝트 파트로 나누며 회원정보 파트에는 회원가입하면서 기재한 내용들을 확인 할 수 있다. 프로젝트 파트에는 프로젝트 페이지로 이동과 모집중인 카드를 볼 수 있다.
회원정보 파트
구성
- 최상단에 본인의 포지션 표시
- 본인의 깃허브로 이동하는 버튼
- 회원가입시, 작성한 한 줄 소개
- 보유 스킬
- 참여한 프로젝트
더보기 버튼 클릭을 통해 프로젝트 페이지로 이동이 가능하다.
본인이 참여한 프로젝트의 제목을 클릭하면 해당 프로젝트의 상세 설명 페이지로 이동한다.
디자인
상단에 위치한 물결을 이미지가 아닌, html과 css 코드를 이용하여 만들었다.
직접 하나하나 만들기에는 어렵기에 wave 사이트의 힘을 빌려 제작하였다. 해당 페이지는 원하는 설정을 하면 이에 해당하는 코드를 만들어준다. 만들어준 코드를 복사하여 붙히기만 하면 끝이다.
- wave 디자인
사이트에서 만든 디자인을 복붙하면 다음과 같이 나온다.
여기에 나는 추가로 배경을 넣어주었다.
배경 이미지를 삽입하고 원하는 것으로 설정해주면 끝이다!<div class="custom-shape-divider-bottom-1652199240"> <svg data-name="Layer 1" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 120" preserveAspectRatio="none"> <path d="M985.66,92.83C906.67,72,823.78,31,743.84,14.19c-82.26-17.34-168.06-16.33-250.45.39-57.84,11.73-114,31.07-172,41.86A600.21,600.21,0,0,1,0,27.35V120H1200V95.8C1132.19,118.92,1055.71,111.31,985.66,92.83Z" class="shape-fill"></path> </svg> </div>
.custom-shape-divider-bottom-1652199240 { position: absolute; bottom: 200px; left: 0; width: 100%; overflow: hidden; line-height: 0; } .custom-shape-divider-bottom-1652199240 svg { position: relative; display: block; width: calc(100% + 1.3px); height: 400px; transform: rotateY(180deg); } .custom-shape-divider-bottom-1652199240 .shape-fill { fill: #FFFFFF; } /* wave 배경 이미지 설정 */ .member-info { margin-top: 200px; background-image: url("../images/home_back.svg"); background-repeat: no-repeat; background-size: cover; }
투명도 설정
내가 만든 박스에 투명도를 넣어주고 싶다면 가장 간단한 방법은 opacity를 통해 투명도를 넣어주는 것이다.
그래서 나는 회원정보의 박스에만 투명도를 약간 주기 위해서 opacity를 사용하였다. 그런데, 배경에도 같이 투명도가 들어갔다.
- 문제점
opacity를 이용하여 박스에 투명도를 주려고 했으나 그의 부모 요소인 배경또한 같이 투명해짐..member-info { margin-top: 200px; background-image: url("../images/home_back.svg"); background-repeat: no-repeat; background-size: cover; } /* 얘도 같이 투명해짐 (부모요소) */ .member-info .text-body .row { opacity: 0.9; /* 배경 + 자식요소까지 투명해짐*/ }
- 해결방법
opacity를 사용하는 것이 아닌, background-color rgba()를 사용하여 투명도를 준다. 이렇게 하면 원하는 배경만을 투명하게 할 수 있다..member-info .text-body .row { background-color: rgba(255,255,255,0.9); }
프로젝트 파트
구성
- 프로젝트 페이지로 이동하기 버튼
- 모집중 카드 슬라이드
Swiper
new Swiper(선택자, 옵션)
의 형태이다.
공지사항 등의 다양한 슬라이드 기능을 가지고 있다.
나는 카드가 자동으로 슬라이드 되게 하는 것과 방향 버튼 클릭시 해당 방향으로 슬라이드가 넘어가는 기능을 구현했다.
HTML
<!-- Swiper -->
<link rel="stylesheet" href="https://unpkg.com/swiper@8/swiper-bundle.min.css"/>
<script src="https://unpkg.com/swiper@8/swiper-bundle.min.js"></script>
--------------------------
<section class="project">
<div class="inner">
<div class="swiper">
<!-- 카드 내용 -->
<div class="card-list swiper-wrapper">
...
<a href="#" onclick="location.href='./project/project_info.html'" class="card swiper-slide">
...
</a>
</div>
<!-- 슬라이드 버튼 -->
<div class="swiper-prev">
<div class="material-icons">arrow_back</div>
</div>
<div class="swiper-next">
<div class="material-icons">arrow_forward</div>
</div>
</div>
</div>
</section>
- Swiper 적용
나는 cdn 방식으로 Swiper를 적용하였다. - 방향 버튼 생성
앞 뒤 방향 클릭시 해당 방향으로 이동하기 위한 버튼을 만들었다.
JS
// new Swiper(선택자, 옵션)
new Swiper('.project .swiper', {
slidesPerView: 4, // 한번에 보여줄 슬라이드 개수
spaceBetween: 10, // 슬라이드 사이 여백
centeredSlides: true, // 1번 슬라이드가 가운데 보이기
loop: true,
autoplay: {
delay: 5000 // 5초 , 밀리세컨 단위
},
navigation: {
prevEl: '.project .swiper-prev',
nextEl: '.project .swiper-next'
}
});
- 선택자는
.project .swiper
이다. - 옵션
slidesPerVeiw: 한번에 보여줄 슬라이드 개수
spaceBetween: 슬라이드 사이 여백
centerSides: 1번 슬라이드가 가운데 보이게 설정하기
loop: 반복 옵션, autopaly의 delay를 통해 시간 설정
navigation: Swiper에서 제공하는 앞 뒤로 이동할 수 있도록 하는 네비게이션 (버튼)
prevEl에는 뒤로 이동할 버튼을, nextEl에는 앞으로 이동할 버튼
마무리
저번에도 느꼈지만 home을 만들면서 더욱 느낀것은 작성해야 할 css 선택자가 늘어나는게 굉장히 비효율적이고 실수도 잘 나올 수 있게 한다는 것이다. SCSS를 알게되면 이렇게 길어지지 않아도 된다고 들었던 것같은데, 빨리 배워서 좀 더 간결하고 깔끔하게 만들고 싶다..!
Comments