All-in-One 기초모듈

Last updated - 2024년 11월 21일 Edit Source

해당 게시글은 HTML/CSS All-in-one : 기초부터 Bootstrap, SASS, 고급 animation 까지 강의를 정리한 내용입니다.


# HTML


# HTML 태그

  • 띄어쓰기를 하고 원하는 class 붙이면 클래스 2개 이상 가능
1
<div class="container text-center"></div>

# input 태그 name 속성

  • input 태그에 name 속성을 지정하면 서버에 name에 해당하는 변수로 데이터를 전송
1
2
<input type="text" name="age" />
<!-- age라는 변수로 서버에 전송 -->

  • 서버에 데이터 전송할 때 방식 2개

    1. <input type="submit">
    2. <button type="submit">전송</button>

# select 태그

  • 드롭다운 구현 가능
1
2
3
4
5
<select>
	<option>자장면</option>
	<option>짬뽕</option>
	<option>탕수육</option>
</select>

# label 태그

  • input 태그 체크박스 활용할 때 의미 없는 글자는 span 태그를 사용해도 되지만, label 태그를 이용해보자.

  • input태그의 id와 label 태그의 for를 동일하게 맞춰주면 label 태그의 글자를 클릭해도 체크박스가 선택된다.

1
<input id="sub" type="checkbox" /> <label for="sub">Subscribe</label>

# table

  • table 태그로 감싸며 thead 태그와 tbody 태그를 써주는 것이 보기 좋다.

  • 그리고 tr 태그로 행 먼저, 그 이후 td 태그로 열, 아래는 3행 3열 테이블

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
<table>
	<thead>
		<tr>
			<td></td>
			<td></td>
			<td></td>
		</tr>
	</thead>
	<tbody>
		<tr>
			<td></td>
			<td></td>
			<td></td>
		</tr>
		<tr>
			<td></td>
			<td></td>
			<td></td>
		</tr>
	</tbody>
</table>
  • 셀 병합을 할때는 <td colspan="4"></td>와 같이 colspan에 합치기 원하는 숫자를 넣기

  • 추가로 html 테이블에서 td의 width를 설정하면 전체 열의 width가 변한다.


# CSS


# float 속성

  • float는 요소를 공중에 붕 띄워서 왼쪽/오른쪽 정렬하는 속성

  • 공중에 붕 띄는 속성 때문에 다음에 오는 div 박스가 보이지 않는 경우 발생

  • clear: both를 이용해서 초기화 해줘야함

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
.box_practice .article01 {
	float: left;
}

.box_practice .article02 {
	float: right;
}

.box_practice .footer {
	clear: both;
}

참고
float 속성으로 가로 정렬할 때 float 박스들을 감싸난 하나의 큰 div 박스를 만들고
폭을 지정해주는게 좋다. 그래야 모바일에서 흘러넘치지 않는다.

1
2
3
4
5
<div>
	<div class="left-box"></div>
	<div class="right-box"></div>
	<div class="footer"></div>
</div>

# Selector 셀렉터

  • 셀렉터 사용 시 공백 말고 꺽쇠( > )도 가능

  • 단, 꺽쇠 사용 시 4~5개 이상 연달아쓰는건 권장X 버그의 원인

1
2
3
4
5
6
7
<ui class="navbar">
	<li><span>안녕</span></li>
	<li></li>
	<li></li>
	<li></li>
	<li></li>
</ui>
1
2
3
.navbar li > span {
	color: red;
}

  • nth-child() 셀렉터는 여러 요소 중 원하는 n번째 요소에 스타일을 주기 위함이다.
1
2
3
4
5
6
7
.cart-table td:nth-child(2) {
	color: red;
}

.cart-table td:nth-child(n + 2) {
	color: blue;
}
  • 위의 코드는 2번째에 나오는 td에만 color를 주는 것이고

  • 아래의 코드는 2번째 이후에 나오는 td들에 color를 주겠다는 것


# background 속성

  • 그냥 이미지를 넣어도 되지만, background도 생각

  • background-image: url(./img/img03.png); 배경 이미지 설정 (이때, url 여러개 넣어서 배경 겹치기 가능)

  • background-size: cover; 배경 이미지 div 박스에 꽉차게

  • background-size: contain; 배경 이미지 잘리지 않게

  • background-repeat: no-repeat; 반복되는거 없애기

  • background-position: center; center를 기준으로 배경 채움

  • background-attachment: fixed; 스크롤 될 때 배경 동작 설정 방식

  • filter: brightness(50%) 배경에 보정 입히기 - 명도 (단, 안에 글씨 있으면 글씨도 필터가 입혀지니까 이는 조심하자.)


# 배경에 검은색 틴트 주기

1
2
3
4
.main-background {
	background-image: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)),
	url(이미지경로~~);
}

# margin collapse 현상

margin collapse 현상은, div 박스 두 개가 겹친 경우에 박스 2개의 위쪽 테두리가 겹치면, margin도 합쳐지는 현상을 의미한다.


1
2
3
<div class="main-background">
	<h4 class="main-title">Buy Our Shoes!</h4>
</div>

이 경우에서 박스 2개가 겹쳐지게 되어, main-title에 margin-top을 주면 margin이 합쳐진 현상이라 같이 내려가게 될 것이다. 해결방안으로는, 테두리가 안붙게 하면 된다. 부모 박스에 padding: 1px과 같은 조작을 취하면 된다.


# 좌표 이동

  • position 속성 부여하여 좌표이동 가능해짐.

  • 특징 01 : 좌표 이동 가능

  • 특징 02 : float와 비슷하게 공중에 뜨는 원리

  • position: relative 내 원래 위치가 기준

1
2
3
4
5
.main-button {
	position: relative;
	top: 100px; // 위쪽에서부터 100px
	left: 100px; // 왼쪽에서부터 100px
}
  • position: static 좌표 이동 금지

  • position: fixed 현재 화면 (viewport) 기준으로 고정

  • navbar 같은거 스크롤 해도 상단에 고정시키면 좋으니까, 그럴 때 사용

  • position: absolute 내 부모 태그 중에 position: relative 가진 부모를 기준으로 한다.

  • position: absolute 요소를 가운데 정렬하는 방법

1
2
3
4
5
6
7
.main-btn {
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	width: 30%;
}

# z-index

  • div 박스가 겹칠 때 우선순위를 두기

  • z-index: 1, z-index: 5 숫자가 클 수록 (높을 수록) 앞에 온다.


# width의 영역에 관한 문제

  • width는 div 박스의 너비가 아니라 width는 내부 content 영역의 너비를 의미한다. padding이나 border에 width는 영향을 주지 않는다.

  • 해결하려면, content 부분만 width로 설정하는 것이 아니라, padding과 border를 모두 포함하라고 시키면 된다.

  • box-sizing: border-box; - width가 padding, border를 포함한다.

  • content-box는 padding과 border를 포함하지 않는 경우이다.

  • 아래의 예제로 box-sizing이 있고 없고를 비교해보기

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
.explain-box {
	position: relative;
	margin: auto;
	padding: 20px;
	text-align: center;
	top: -80px;
	max-width: 600px;
	width: 80%;
	height: 40%;
	background-color: rgb(238, 237, 239);
	box-sizing: border-box;
}

# css 초기 설정시 편한 것, normalize

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12

body {
	margin: 0px;
}

div {
	box-sizing: border-box;
}

html {
	line-height: 1.15; /* 기본 행간 높이 */
}

혹은 크롬, 파이어폭스, 사파리와 같이 브라우저 호환성 이슈가 있을 때 css 파일에 추가하고 시작하면 좋은 설정들이 있다. (버튼의 크기나 이미지가 브라우저마다 다르거나 한 경우 때문에)


normalize.css를 참고하도록 하자.


# input type에 따른 css 셀렉터

  • 아래와 같이 지정하면 input type이 text인 아이들만 css 스타일링 가능
1
2
3
4
5
input[type='text'] {
	padding: 10px;
	font-size: 20px;
	border: 1px solid black;
}

# vertical-align 속성

  • inline/inline-block 요소 간의 세로정렬 할 때 vertical-align을 사용한다.

  • 테이블 사용 시 수직 정렬에도 사용 가능

  • pratice02.html에서 실패했던 이유는 ? div박스와 조작을 시도했기 때문

  • 해결책은 하나의 div 박스 내에서 img와 글자를 span태그로 묶어서 그 둘을 vertical-align 했으면 가능했을 듯하다.

1
2
3
4
5
6
7
8
9
<div>
	<img
	src="https://mdn.mozillademos.org/files/12245/frame_image.svg"
	width="32"
	height="32"
	/>
	<span style="vertical-align : middle;">
	image with a default alignment.</span>
</div>

# table 태그 border-radius 오류

  • border-collapse 속성을 table 태그에 적용했을 때 border-radius가 안먹는 오류가 있다.

  • 첫 번째 해결방안
1
2
3
4
5
6
7
8
table {
	border-collapse: collapse;
	border-spacing: 0;
}

(왼쪽위에있는 td) {
	border-top-left-radius: 5px;
}

  • 두 번째 해결방안
    • box-shadow 속성을 이용하여 테두리를 가짜로 만들어내는 편법
1
2
3
4
5
6
7

table {
	border-collapse: collapse;
	border-radius: 7px;
	border-style: hidden;
	box-shadow: 0 0 0 1px #666;
}

# button 태그 같이 hover 할 때 마우스 커서

  • :hover로 pseudo-class를 하지 않아도 cursor:pointer와 같이 작성하면 올렸을 때 마우스 커서 바뀜
1
2
3
4
5
6
button {
	padding: 15px;
	font-size: 20px;
	border: none;
	cursor: pointer;
}

# input 태그 focus 스타일 안먹힐 때

  • input:focus를 해서 border 속성을 지정했는데 색깔이 안먹는 경우가 있다.
  • 그럴때는 크롬 기본속성인 outline을 none으로 설정해주자.
1
2
3
4
.cart-footer .input-test:focus {
	outline: none;
	border: 2px solid rgb(2, 77, 163);
}

# css의 다양한 pseudo-class

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
/* 외우는법 hofa */

:hover /*마우스를 올려놓을 때*/
:focus /*클릭 후 계속 포커스 상태일 때*/
:active /*클릭 중일 때*/

:link /* 방문 전 링크 */
:visited /* 방문 후 링크 */
:any-link /*방문 전, 방문 후 링크 한번에 선택할 때*/

:playing /*동영상, 음성이 재생중일 때*/
:paused /*동영상, 음성이 정지시*/
:autofill /*input의 자동채우기 스타일*/
:disabled /*disabled된 요소 스타일*/
:checked /*체크박스나 라디오버튼 체크되었을 때*/

:blank /*input이 비었을 때*/
:valid /*이메일 input 등에 이메일 형식이 맞을 경우*/
:invalid /*이메일 input 등에 이메일 형식이 맞지 않을 경우*/
:required /*필수로 입력해야할 input의 스타일*/

:nth-child(n) /*n번째 자식 선택*/
:first-child /*첫째 자식 선택*/
:last-child /*마지막 자식 선택*/

# 코드 양이 줄어드는 class 작명법 (OOCSS, BEM)

  • OOCSS (Object Oriented CSS)

  • CSS 양이 줄어들고, 유지보수 편리

  • 뼈대용 class, 살점용 class 각각 제작

  • 뼈대 디자인을 먼저 분리해놓고 색깔과 같은 살점을 추가하는 방식

1
2
<button class="main-btn bg-red">버튼1</button>
<button class="main-btn bg-blue">버튼2</button>
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
.main-btn {
	padding: 15px;
	font-size: 20px;
	border: none;
	cursor: pointer;
}

.bg-red {
	background: red;
}

.bg-blue {
	background: blue;
}

  • OOCSS를 극단적으로 여러 Utility class를 만들어 놓을 수 있다.
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
.f-small {
	font-size: 12px;
}

.f-mid {
	font-size: 16px;
}

.f-lg {
	font-size: 20px;
}

.bg-red {
	background: red;
}

.bg-blue {
	background: blue;
}
1
<button class="main-btn bg-red f-lg">버튼</button>

  • BEM (Block__Element–Modifier)

  • class 작명할 때 창의력이 부족한 경우 BEM 작명법을 이용할 수 있다.

  • class = "덩어리이름__역할--세부특징"

1
2
3
4
5
6
7
8
<div class="profile">
	<img class="profile__img" />
	<h4 class="profile__title"></h4>
	<p class="profile__content"></p>
	  
	<button class="profile__button--red">버튼1</button>
	<button class="profile__button--blue">버튼2</button>
</div>
  • 사람마다 다르다. OOCSS를 쓰면 html이 더러워져서 추천하지 않는 사람도 있음

  • BEM도 Modifer는 빼고 Block__Element까지만 쓰는 사람도 있음

  • 최근, React나 Vue로 HTML 만들면 굳이 OOCSS, BEM 굳이 안쓰는 경우가 많아서 깊게 익힐 필요 X

  • React나 Vue에서는 html 페이지 단위가 아닌, 작은 덩어리 (component) 단위로 개발하게 된다. 이때 profile과 같이 class 명이 중복되어도 컴포넌트끼리 스타일이 간섭되지 않게 코드 작성이 가능하다. 대표적으로, React의 styled-components 라이브러리를 사용하면 가능하다.

Comment