background-origin: content-box - 배경이 시작되는 위치를 content-box 영역부터 시작한다

background-origin: border-box - 배경이 시작되는 위치를 테두리 영역부터 시작한다



html)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta name="viewport" 
          content="width=device-width, height=device-height, 
                     minimum-scale=1.0, maximum-scale=1.0, initial-scale=1.0">
    <title>Insert title here</title>
    <style>
    div {
        background: url(images/tile.png);
        background-color: #FFA7A7;
        
        /* background-origin: content-box 배경이 시작되는 위치를 content-box에 맞춘다 */
        background-origin: content-box;
        background-clip: content-box;
        
        padding: 30px;
        height: 300px;
        border: 1px solid #000;
    }
    </style>
</head>
 
<body>
    <div></div>
</body>
</html>
cs



결과

배경이미지가 잘려서 보였는데 배경이미지를 content-box에 맞춰서 보여주므로 배경이미지가 정확히 보인다


background-clip: content-box 배경을 content영역에만 보이도록 한다 



html)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta name="viewport" 
          content="width=device-width, height=device-height, 
                     minimum-scale=1.0, maximum-scale=1.0, initial-scale=1.0">
    <title>Insert title here</title>
    <style>
    div {
        background: url(images/tile.png);
        background-color: #FFA7A7;
        /* background-clip: content-box 배경을 content영역에만 보이도록 한다 padding 영역에는 배경이 보이지 않는다 */
        background-clip: content-box;
        
        padding: 30px;
        height: 300px;
        border: 1px solid #000;
    }
    </style>
</head>
 
<body>
    <div></div>
</body>
</html>
cs



결과

background-position : 배경이미지 위치 지정하기



html)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta name="viewport" 
          content="width=device-width, height=device-height, 
                     minimum-scale=1.0, maximum-scale=1.0, initial-scale=1.0">
    <title>Insert title here</title>
    <style>
    /*
    background-position: 가로기준 세로기준
    1) 값을 하나만 지정하는 경우
    left, right, 숫자 : 가로기준으로 적용, 세로기준은 center가 된다
    top, bottom : 세로기준으로 적용, 가로기준은 center가 된다
    2) %로 지정하는 경우
    해당영역의 %위치에 배경이미지의 %가 위치한다
    */
    div {
        background-position: 50% 50%;    /* 이미지가 div 태그 가운데에 오게 된다 */
    
        width: 100%;
        height: 300px;
        background-image: url(images/tile.png);
        background-repeat: no-repeat;
        border: 1px solid #000;
    }
    </style>
</head>
 
<body>
    <div></div>
</body>
</html>
cs



결과

%로 지정했으므로 이미지의 가운데(50% 50%)가 div 태그의 가운데(50% 50%)에 위치한다


background-repeat 배경이미지 반복여부 설정



background-image: url(경로) 배경이미지 파일경로 지정


background-repeat: 반복여부

repeat 반복

no-repeat 반복안함

repeat-x 가로방향 반복

repeat-y 세로방향 반복



html)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta name="viewport" 
          content="width=device-width, height=device-height, 
                     minimum-scale=1.0, maximum-scale=1.0, initial-scale=1.0">
    <title>Insert title here</title>
    <style>
    div {
        height: 130px;
        border: 1px solid #000;
        margin-bottom: 5px;
    }
    
    /*
    background-image: url(경로) 배경이미지 파일경로 지정
    background-repeat: 반복여부
    repeat 반복
    no-repeat 반복안함
    repeat-x 가로방향 반복
    repeat-y 세로방향 반복
    */
    .repeat {
        background-image: url(images/tile.png);
        background-repeat: repeat;
    }
    .no-repeat {
        background-image: url(images/tile.png);
        background-repeat: no-repeat;
    }
    .repeat-x {
        background-image: url(images/tile.png);
        background-repeat: repeat-x;
    }
    .repeat-y {
        background-image: url(images/tile.png);
        background-repeat: repeat-y;
    }
    </style>
</head>
 
<body>
    <div class="repeat"></div>
    <div class="no-repeat"></div>
    <div class="repeat-x"></div>
    <div class="repeat-y"></div>
</body>
</html>
cs



결과

table 태그 쓰지 않고 테이블 표현하기



display 속성 중 table 관련 속성

table -> table

table-caption -> caption

table-cell -> td

table-column -> col

table-column-group -> colgroup

table-footer-group -> tfoot

table-header-group -> thead

table-row -> tr

table-row-group -> tbody



html)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta name="viewport" 
          content="width=device-width, height=device-height, 
                     minimum-scale=1.0, maximum-scale=1.0, initial-scale=1.0">
    <title>Insert title here</title>
    <style>
    /*
    display 속성 중 table 관련 속성
    table -> table
    table-caption -> caption
    table-cell -> td
    table-column -> col
    table-column-group -> colgroup
    table-footer-group -> tfoot
    table-header-group -> thead
    table-row -> tr
    table-row-group -> tbody
    */
    .table {
        display: table;
        width: 100%;
        background: #DAD9FF;
    }
    .table-row-group {
        display: table-row-group;
    }
    .table-row {
        display: table-row;
        height: 40px;
    }
    .table-cell {
        display: table-cell;
        border-bottom : 1px solid #000;
        text-align: center;
        vertical-align: middle;
    }
    .content {
        font-weight: bold;
    }
    </style>
</head>
 
<body>
<div class="table">
    <div class="table-row-group">
        <div class="table-row">
            <div class="table-cell content">01</div>
            <div class="table-cell">제목을 입력하세요</div>
            <div class="table-cell">2017-04-10</div>
        </div>
        <div class="table-row">
            <div class="table-cell content">02</div>
            <div class="table-cell ">제목을 입력하세요2</div>
            <div class="table-cell">2017-04-11</div>
        </div>
    </div>
</div>
</body>
</html>
cs



결과


페이징 구성하기



html)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta name="viewport" 
          content="width=device-width, height=device-height, 
                     minimum-scale=1.0, maximum-scale=1.0, initial-scale=1.0">
    <title>Insert title here</title>
    <style>
    .paging {
        text-align: center;
    }
    .paging a {
        /*
        display: inline-block 인라인 요소의 특징과 블록 요소의 특징을 모두 갖는다
        크기를 가질 수 있으며 텍스트 정렬도 적용받는다
        */
        display: inline-block;
        
        font-weight: bold;
        text-decoration: none;
        padding: 5px 8px;
        border: 1px solid #ccc;
        color: #000;
        background-color: #F5F5DC;
    }
    /* 현재 페이징에 select 클래스를 적용한다*/
    .paging a.select {
        color: #fff;
        background-color: #FFA7A7;
    }
    </style>
</head>
 
<body>
    <div class="paging">
        <a class="select" href="#">1</a>
        <a href="#">2</a>
        <a href="#">3</a>
        <a href="#">4</a>
        <a href="#">5</a>
    </div>
</body>
</html>
cs



결과

word-break, white-space : 줄바꿈 속성



word-break : break-all  상위 블록의 width를 넘어서게 되면 단어를 깨뜨려 줄을 바꾸게 된다

white-space: nowrap    줄바꿈 금지

white-space: pre         작성한 그대로 (pre태그)

white-space: pre-wrap  pre효과와 비슷하지만 지정한 영역을 넘어가지 않음

white-space: pre-line    pre-wrap효과와 비슷하지만 띄어쓰기 공백은 한칸만 표현



html)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta name="viewport" 
          content="width=device-width, height=device-height, 
                     minimum-scale=1.0, maximum-scale=1.0, initial-scale=1.0">
    <title>Insert title here</title>
    <style>
    div {
        width: 100%;
    }
    p {
        background: #CEFBC9;
    }
    
    /*
    word-break : break-all 상위 블록의 width를 넘어서게 되면 줄을 바꾸게 된다
    white-space: nowrap    줄바꿈 금지
    white-space: pre            작성한 그대로 (pre태그)
    white-space: pre-wrap  pre효과와 비슷하지만 지정한 영역을 넘어가지 않음
    white-space: pre-line  pre-wrap효과와 비슷하지만 띄어쓰기 공백은 한칸만 표현
    */
    p.word_break {
        word-break : break-all;
    }
    p.nowrap{
        white-space: nowrap;
    }
    p.pre {
        white-space: pre;
    }
    p.pre_wrap {
        white-space: pre-wrap;
    }
    p.pre_line {
        white-space: pre-line;
    }
    </style>
</head>
 
<body>
<div>
    <p class="word_break">이에 재판관 전원의 일치된 의견으로 주문을 선고합니다. 주문, 피청구인 대통령 박근혜를 파면한다.</p>
    <p class="nowrap">이에 재판관 전원의 일치된 의견으로 주문을 선고합니다. 주문, 피청구인 대통령 박근혜를 파면한다.</p>
    <p class="pre">이에 재판관 전원의 일치된 의견으로 주문을 선고합니다. 주문, 피청구인 대통령 박근혜를 파면한다.</p>
    <p class="pre_wrap">이에 재판관 전원의 일치된 의견으로 주문을 선고합니다. 주문, 피청구인 대통령 박근혜를 파면한다.</p>
    <p class="pre_line">이에 재판관 전원의 일치된 의견으로 주문을 선고합니다. 주문, 피청구인 대통령 박근혜를 파면한다.</p>
</div>
</body>
</html>
cs



결과

이미지, 텍스트 수직으로 가운데 정렬하기



html)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta name="viewport" 
          content="width=device-width, height=device-height, 
                     minimum-scale=1.0, maximum-scale=1.0, initial-scale=1.0">
    <title>Insert title here</title>
    <style>
    /*
    이미지, 텍스트를 담을 div에 line-height 속성을 준다
    이미지 텍스트에 vertical-align: middle 속성을 준다
    */
    div {
        height: 200px;
        line-height: 200px;
        border: 1px solid;
        background: #DAD9FF;
    }
    /*
    vertical-align: baseline : 글자의 baseline에 맞춤
    vertical-align: top      : 부모요소의 상단에 맞춤
    vertical-align: middle      : 부모요소의 가운데에 맞춤
    vertical-align: bottom      : 부모요소의 하단에 맞춤
    
    vertical-align: super      : 부모요소의 위첨자에 맞춤
    vertical-align: sub      : 부모요소의 아래첨자에 맞춤
    vertical-align: text-top : 부모요소의 글꼴 상단에 맞춤
    vertical-align: text-bottom : 부모요소의 글꼴 하단에 맞춤
    */
    img.align {
        vertical-align: middle;
    }
    p {
        vertical-align: middle;
    }
    </style>
</head>
 
<body>
    <div>
        <img class="align" src="images/testimage.jpg" height="150px" />
    </div>
    <div>
        <span>가나다라마바사아자차카타파하</span>
    </div>
</body>
</html>
cs



결과



text-index : 글자 들여쓰기



html)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta name="viewport" 
          content="width=device-width, height=device-height, 
                     minimum-scale=1.0, maximum-scale=1.0, initial-scale=1.0">
    <title>Insert title here</title>
    <style>
    p {
        font-size: 1.3em;
        background: #CEFBC9;
    }
    
    /* 
    text-index : 글자 들여쓰기 ( - 이면 내어쓰기가 됨)
    */
    p.letter {
        text-indent : 1em;
    }
    p.number {
        text-indent : -1em;
    }
    </style>
</head>
 
<body>
    <p class="letter">가나다라마바사아자차카타파하 아야어여오요우유으이 0123456789</p>
    <p class="number">1234567890</p>
</body>
</html>
cs



결과


letter-spacing : 글자 사이의 간격

word-spacing : 단어 사이의 간격

line-height : 줄 간격 (글자 높이 포함)



html)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta name="viewport" 
          content="width=device-width, height=device-height, 
                     minimum-scale=1.0, maximum-scale=1.0, initial-scale=1.0">
    <title>Insert title here</title>
    <style>
    /* 
    letter-spacing: 글자사이의 간격
    word-spacing: 단어사이의 간격
    line-height: 줄간격 (글자 높이 포함)
    */
    h1 {
        letter-spacing: 0.3em;
    }
    p {
        word-spacing: 0.5em;
        font-size: 1.3em;
        line-height: 2;    /* 단위가 지정되지 않으면 배수(2배)라는 뜻 */
    }
    </style>
</head>
 
<body>
    <h1>글자 사이의 간격</h1>    
    <p>바나나 사과 딸기 복숭아 수박 파인애플 귤 오렌지 블루베리</p>
</body>
</html>
cs



결과



+ Recent posts