Web/HTML&CSS

[CSS] CSS 개념 및 구성 요소

_eunji_ 2022. 4. 5. 22:43

CSS란?

CSS는 Cascading Style Sheet의 약자로, HTML로 작성된 정보를 꾸며주는 언어이다.


 

CSS 구성 요소

선택자 { 속성 : 속성값; }

- 선택자: 디자인을 적용할 HTML 영역

- 속성: 어떤 디자인을 적용할지 정의

- 속성 값: 어떤 역할을 수행할지 구체적으로 명령

 

 

CSS 속성 (Property)

h1 {
    font-size: 10px; /* 폰트 사이즈 */
    font-family: sans-serif; /* 글꼴 */
    color: blue; /* 폰트 색깔 */
    background-color: pink; /* 배경색 */
    text-align: center; /* 텍스트 정렬 */
}

 

 

CSS 연동 방법

  • Inline Style Sheet
  • Internal Style Sheet
  • External Style Sheet

 

Inline Style Sheet

<h1 style="color: red;">Hello</h1>

-  태그 안에 직접 원하는 스타일 적용

 

 

Internal Style Sheet

<head>
    <style>
        h1 { background-color: yellow;}
    </style>
</head>

- <style>태그 안에 넣기

 

 

External Style Sheet

<head>
    <link rel="stylesheet" href="style.css">
</head>

- <link>태그로 불러오기

- html, css 각각의 문서 안에서 따로 관리하여 상대적으로 가독성이 높고 유지보수가 쉽다

 

 


 

 

CSS 선택자

  • Type Selector
  • Class Selector
  • ID Selector

 

Type Selector

<!-- <h2> Type Hello World </h2> -->
<style>
    h2 { color: red; }
</style>

- 특정 태그에 스타일 적용

 


Class Selector

<!-- <h2 class="class"> Class Hello World </h2> -->
<style>
    .class { color: blue; }
</style>

- 클래스 이름으로 특정 위치에 스타일 적용

 


ID Selector

<!-- <h2 id="id"> ID Hellow World </h2> -->
<style>
    #id { color: green; }
</style>

- ID를 이용해 스타일 적용

 

 


 

 

부모 자식 관계

<header>
	<h1>Header h1</h1>
    <p>Header p</p>
</header>
<footer>
	<h1>Footer h1</h1>
    <p>Footer p</p>
</footer>

- <header>와 <h1><p> : 부모 자식 관계

- <h1>과 <p> : 형제 관계

 

- 부모의 css 일부를 자식이 상속받을 수 있다

- 원하는 지역에만 css 속성을 적용하기 위해 부모를 구체적으로 표기

 

 


 

 

CSS 우선순위를 결정하는 세 가지 

  • 순서
  • 디테일
  • 선택자

 

1. 순서 - 나중에 적용한 속성값의 우선순위가 높음

p { color: red; }
p { color: blue; ]

 

2. 디테일 - 구체적으로 작성된 선택자의 우선순위가 높음

header p {color: red; }
p { color: blue; }

 

3. style > id > class > type 순으로 우선순위가 높음

<h3 style="color: pink" id="color" class="color"> color </h3>

#color { color: blue; }
.color { color: red; }
h3 {color: green; }

 

 


 

 

CSS 주요 속성

  • width, height
  • font
  • border
  • background

 

width, height

<p class="hello"> 안녕하세요 </p>

.hello { width: 500px, height: 500 px; }
  • .width 속성: 선택한 요소의 넓이를 설정
  • .height 속성: 선택한 요소의 높이를 설정
  • 고정값은 px, 가변 값은 %로 표기


font

<p class="hello"> 안녕하세요 </p>

.hello {
    font-size: 20px; /* 글자 크기 */
    font-family: Arial, sans-serif; /* 글꼴 */
    font-style: italic; /* 글자 기울기 */
    font-weight: bold; /* 글자 두께 */
  • .font-family: 브라우저마다 지원하는 폰트가 다름. 입력한 순서대로 우선순위 적용. sans-serif는 모든 브라우저에서 지원 가능하기 때문에 마지막에 작성하는 디폴트 값.
  • .font-weight: 100-900 사이의 숫자를 입력할 수도 있음.


border

<p class="hello"> 안녕하세요 </p>

.hello {
    width: 500px; 
    height: 500px; 
    border-style: solid;
    border-width: 10px;
    border-color: red;
    
    /* border: solid 10px red; */
  • .border-style: 실선은 solid, 점선은 dotted로 표기
  • 주석과 같이 한 줄에 이어 쓸 수도 있음. 이때, 쉼표는 작성하지 않고 띄어쓰기만 함 (순서 상관 X)


background

<p class="hello"> 안녕하세요 </p>

.hello {
    background-color: yellow;
    background-image: url(이미지 경로);
    background-repeat: no-repeat;
    background-position: left;
    
    /* background: yellow url(이미지 경로) no-repeat left; */
  • .background-repeat: x축으로 반복은 repeat-x, y축으로 반복은 repeat-y, 반복하지 않은 경우 no-repeat으로 표기
  • .background-position: 공간 안에서 이미지의 좌표 변경 (top, bottom, center, left, right 등)
  • 주석과 같이 한 줄에 이어 쓸 수도 있음. 이때, 쉼표는 작성하지 않고 띄어쓰기만 함 (순서 상관 X)