헤드 안에 스크립트로 부트스트랩 깔아주고, 적당하게 탭기능 틀을 만들어주었다
원하는 것은 탭버튼을 눌렀을때 그에 해당하는 콘텐츠div가 등장하는것
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-1BmE4kWBq78iYhFldvKuhfTAU6auU8tT94WrHftjDbrCEXSU1oBoqyl2QvZ6jIW3" crossorigin="anonymous">
<link href="./main.css" rel="stylesheet">
<title>Hello, world!</title>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.0/jquery.min.js" integrity="sha512-894YE6QWD5I59HgZOGReFYm4dnWc1Qt5NtvYSaNcOP+u1T9qYdvdihz0PPSiiqn/+/3e7Jo4EaG7TubfWGUrMQ==" crossorigin="anonymous" referrerpolicy="no-referrer"></script>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/js/bootstrap.bundle.min.js" integrity="sha384-ka7Sk0Gln4gmtz2MlQnikT1wXgYsOg+OMhuP+IlRH9sENBO0LRn5q+8nbTov4+1p" crossorigin="anonymous"></script>
</head>
<body>
<style>
ul.list {
list-style-type: none;
margin: 0;
padding: 0;
border-bottom: 1px solid #ccc;
}
ul.list::after {
content: '';
display: block;
clear: both;
}
.tab-button {
display: block;
padding: 10px 20px 10px 20px;
float: left;
margin-right: -1px;
margin-bottom: -1px;
color: grey;
text-decoration: none;
cursor: pointer;
}
.orange {
border-top: 2px solid orange;
border-right: 1px solid #ccc;
border-bottom: 1px solid white;
border-left: 1px solid #ccc;
color: black;
margin-top: -2px;
}
.tab-content {
display: none;
padding: 10px;
}
.show {
display: block;
}
</style>
<div class="container mt-5">
<ul class="list">
<li class="tab-button">Products</li>
<li class="tab-button orange">Information</li>
<li class="tab-button">Shipping</li>
</ul>
<div class="tab-content">
<p>상품설명입니다. Product</p>
</div>
<div class="tab-content show">
<p>스펙설명입니다. Information</p>
</div>
<div class="tab-content">
<p>배송정보입니다. Shipping</p>
</div>
</div>
<script src = "tab.js"></script>
</body>
</html>
차곡차곡 한글로 쓴뒤
코드로 번역해준다
//0번째 tab-button부터 기능개발 해보자
/*버튼 0 누르면 (코드를 한줄한줄 읽으니까 제거먼저 하고 추가해주는 센스~)
- 모든버튼에 붙은 orange 클래스명 제거
- 버튼 0에 orange 클래스명 추가
- 모든 div에 붙은 show 클래스명 제거
- div0에 show 클래스명 추가
*/
$('.tab-button').eq(0).on('click',function(){
$('.tab-button').removeClass('orange');
$('.tab-button').eq(0).addClass('orange');
$('.tab-content').removeClass('show');
$('.tab-content').eq(0).addClass('show');
});
/*버튼 1 누르면
- 모든버튼에 붙은 orange 클래스명 제거
- 버튼 1에 orange 클래스명 추가
- 모든 div에 붙은 show 클래스명 제거
- div1에 show 클래스명 추가
*/
$('.tab-button').eq(1).on('click',function(){
$('.tab-button').removeClass('orange');
$('.tab-button').eq(1).addClass('orange');
$('.tab-content').removeClass('show');
$('.tab-content').eq(1).addClass('show');
});
/*버튼 2 누르면
- 모든버튼에 붙은 orange 클래스명 제거
- 버튼 2에 orange 클래스명 추가
- 모든 div에 붙은 show 클래스명 제거
- div2에 show 클래스명 추가
*/
$('.tab-button').eq(2).on('click',function(){
$('.tab-button').removeClass('orange');
$('.tab-button').eq(2).addClass('orange');
$('.tab-content').removeClass('show');
$('.tab-content').eq(2).addClass('show');
});
3개 코드가 괄호안의 숫자만 다르고
굉장히 비슷한 코드이지 않나요?
반복문을 사용해서 간단하게 만들어봅시다
for(let i =0; i < $('.tab-button').length; i++){
$('.tab-button').eq(i).on('click',function(){
$('.tab-button').removeClass('orange');
$('.tab-button').eq(i).addClass('orange');
$('.tab-content').removeClass('show');
$('.tab-content').eq(i).addClass('show');
});
}
선생님 말씀 :
for 문법의 용도를 잘 기억해둡시다.
비슷한 코드들을 직접 복붙하는게 귀찮으면 for 반복문을 쓰는 것일 뿐이지
for 부터 써놓고 무슨 코드를 채울지 고민하고 그러면 안됩니다.
'Javascript' 카테고리의 다른 글
데이터 바인딩으로 상품의 가격,이름 넣기 (0) | 2023.03.20 |
---|---|
이벤트 버블링 (0) | 2023.03.20 |
스크롤 이벤트로 만드는 재밌는 기능들 (0) | 2023.03.19 |
이미지 슬라이드 만들기 (0) | 2023.03.19 |
정규식으로 이메일형식 검증해보기 (0) | 2023.03.19 |