티스토리 뷰

코딩/HTML&CSS

[6주차 1일] CSS

ehzim 2023. 11. 13. 17:45

 

 

 

작성 절차

1. HTML 코드 작성

2. 가로 / 세로 배치

    - 정렬 : 부모 → 자식 (display:flex; 자식을 가로 세로 정렬한다.)

    - 정렬 : 자기자신(스스로 위치 잡음)

position : relative, absolute

margin, padding

 

3. width   X  /    height    X (자기자신꾸미고 text 꾸밀때 사용)

4. background-color 주기

 

 

 

HTML

<!DOCTYPE html>
<html lang="en">
<head>
    <link rel="stylesheet" href="style.css">
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://kit.fontawesome.com/5aa76ca121.js" crossorigin="anonymous"></script>
    <link rel="preconnect" href="https://fonts.googleapis.com">
    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
    <link href="https://fonts.googleapis.com/css2?family=Hahmlet:wght@200;400&display=swap" rel="stylesheet">
</head>
<body>
    <nav>
        <div id="logobox">   
            <div id="logo"><i class="fas fa-utensils"></i></div>
            <div id="title">itedunet</div>
        </div>
        <div id="listbox">
            <ul>
                <li><a href="">Home</a></li>
                <li>Serviceoffers</li>
                <li>Skills</li>
                <li>Work</li>
                <li>Testimonials</li>
                <li>Contact</li>
            </ul>
        </div>
    </nav>
</body>
</html>

 

 

CSS

*{
    font-family: 'Hahmlet', serif;
    list-style: none;/*li의 스타일을 없앰*/
    margin: 0px;
    padding: 0px; /*margin과 padding을 0으로 하여 초기화함*/
}
/*네비게이션바 시작*/
nav
{
    /*부모설정*/
    display:flex;
    /*flex는 자식 요소가로 펼치기*/
    justify-content: space-between; /*가로정렬*/
    /*space-around:요소좌우 공백 n/1 space-between:양끝 정렬 space-evenly:공백을 똑같이 생성*/

    /*자기자신 설정*/
    padding:10px; 
    align-items: center;
    /*flex-start:위쪽 flext-end:아래쪽 center:중앙 */
    background-color: pink;
    color: white;
}
/*네비게이션바 끝*/
#logobox
{
    /*부모설정*/
    display:flex;
    justify-content: left;/*가로정렬*/
    align-items: flex-end;/*세로정렬*/
    /*자신설정*/
    border: 1px solid white;
    background-color: lightblue;
    margin:10px;
}
#logo
{
    margin-right: 10px;
}
#listbox
{
    /*부모설정*/

    
}
#listbox>ul
{
    display:flex;
    justify-content: right;
    align-items: flex-end;
    margin-left: 20px;
}
ul>li
{
    border:1px solid white;
    padding: 0 10px; /*좌우만 패딩값들어감*/
    /*시계 방향 상우하좌 두개값이면 상하 좌우 값으로 봄*/

}
li>a{
    border: 1px solid white;
    padding:0 10px 20px 10px;
    /*패딩을 했는데 사이즈가 부모를 넘어서면서 반영되지
    않을 경우 블록 요소가 아니라서 반영안되는 경우가 종종 발생한다.
    이럴 경우 아래와 같이 변경한다.*/
    display: inline-block;
}

 

 

padding은 반응형이기 때문에 거의 패딩으로 사용한다.

height width는 %으로 사용할 수 있다.(숫자로는 안하는것을 권장)

형제끼리는 영향을 받지않음

(형제의 영향을 받으려면 자신의 크기에 %로 주면 부모 영향을 받아 크기가 같이 커진다. )

 

 

 

 

결과

 

'코딩 > HTML&CSS' 카테고리의 다른 글

[6주 2일차]HTML&CSS  (0) 2023.11.14
[6주차 2일] CSS  (0) 2023.11.14
[5주차 5일] CSS  (0) 2023.11.10
[5주차 4일] CSS  (0) 2023.11.09
[5주차 3일] CSS  (0) 2023.11.08
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday