• 회원가입
  • 로그인
  • 구글아이디로 로그인

[background] CSS - background-image 속성 ★ - 배경이미지 (= background-image속성 = 백그라운드이미지속성, 상속 X) ※ 무한 슬라이드

목차
  1. background-image 정의
  2. background-image 구문 ★
  3. background-image 예제 - 상속 X, 단 영향은 미침
  4. background-image 예제 - 자식요소 margin 부분은 포함 X
  5. background-image 예제 - 자식요소 margin 부분도 포함 O
  6. background-image 예제 - 배경이미지 무한 슬라이드
  7. background-image 예제 - 이미지주소를 base64 코드 사용하기

 

background-image 정의 

 

요소에 하나 이상의 배경이미지 설정.

 


 
1.
배경이미지는 요소 왼쪽상단모서리에 배치되며 수직/수평 반복.
ps. 
반복 안되게 하려면, background-repeat:no-repeat 속성 추가.
 
2.
요소 배경은 padding /border 포함 요소의 전체 크기임. (margin은 제외)
앞서 https://homzzang.com/css/32 에서도 설명드렸지만,
부모요소에 테두리 안 주면 자식요소 부분에만 배경이미지 생김. 
 
3.
배경이미지 비작동 대비해 항상 background-color 속성도 설정 권장.
 
4.
  • 기본값 : none
  • 상속여부 : X
  • 애니효과 : X
  • CSS버전 :CSS1 + CSS3에서 새로운 속성값 추가.
  • JS구문 : object.style.backgroundImage="url(img_girl.gif)"
 
5.
스프라이트 이미지 (Sprite Image : 여러 이미지를 한 이미지 파일에 모아놓은 통파일 된 배경이미지) 사용해 이미지 요청 개수 줄이면 로딩 속도 개선됨.
background-position 속성 이용해 각각의 이미지 선택.
(예) 
 
6.
모든 브라우저 모두 지원.
 
7. 예제 더 보기
 

 

background-image 구문 ★

 

selector {background-image: url('URL주소')|none|initial|inherit;}

 


[속성값]

 

url ( 'URL주소')

이미지 URL 주소.

 

none

배경이미지 사용 안 함. (기본값)

 

linear-gradient()
선형 그레이디언트를 배경이미지로 설정.

  • 최소 두 가지 이상의 색상 정의 (위에서 아래로)

 

radial-gradient()

방사형 그레이디언트를 배경이미지로 설정.

  • 최소 두 가지 색상 정의 (중심에서 변방으로)

  

repeating-linear-gradient()

선형 그레이디언트 반복

 

repeating-radial-gradient ()

방사형 그레이디언트 반복.

 

initial

이 속성의 기본값으로 설정.

 

inherit

부모 요소의 속성값 상속.

 


PS. 여러 속성값 동시 사용 가능. (※ 첫 번째 것이 맨위에 옴.)

예제
background-image: linear-gradient(to bottom,rgba(17,17,17,0.5) 10%, rgba(17,17,17,0.85) 30%), url('이미지주소');
 

 

background-image 예제 - 상속 X, 단 영향은 미침

부모요소에서 배경이미지 지정하면, 그 효과가 자식요소인 h1에도 미침.

다만,
명백한 상속 표시 위해, 자식요소에 background-image: inherit; 표기.


<style>
div {
    width:400px; 
    height:60px;
    background-image: url("http://i.imgur.com/MzHQIAK.jpg"); 
    border:1px solid brown;
}
h1 {
    margin:10 10 10 10px;
    color:white;
    background-image: inherit; 
}
</style>
 
<div>
    <h1>홈짱닷컴 (homzzang.com)</h1>

 

background-image 예제 - 자식요소 margin 부분은 포함 X

※ 부모요소 div에 border 값을 안 주면 자식요소 margin 포함 X.

<style>
div {
   background-image: url("http://i.imgur.com/MzHQIAK.jpg"); 
}
h1 {
   background-image: inherit; 
}
</style>
 
<div>
    <h1>홈짱닷컴 (homzzang.com)</h1>
</div>
 

 

background-image 예제 - 자식요소 margin 부분도 포함 O

※ 부모요소에 border 줘서 자식요소 margin에도 배경이미지 주기.


<style>
div {
    background-image: url("http://i.imgur.com/MzHQIAK.jpg");
    border: 1px solid red; 
}
h1 {
    background-image: inherit; 
}
</style>
<div>
    <h1>홈짱닷컴 (homzzang.com)</h1>
</div>
 

PS. 부모요소에 border 줘도 자식요소에 배경이미지 설정 시, margin 포함 X.

 

<style>

div { border: 1px solid red; }

h1 { background-image: url("http://i.imgur.com/MzHQIAK.jpg"); }

</style>


<div>

    <h1>홈짱닷컴 (homzzang.com)</h1>

</div>

 

 

background-image 예제 - 배경이미지 무한 슬라이드

 

<style>

body {

  display: flex;

  flex-direction: row;

  justify-content: center;

  align-content: center;

  align-items: center;

  flex-wrap: wrap;

  width: 100vw;

  height: 100vh;

}


.infinite-photo-grid {

  width: 100%;

  height: 100%;

  max-height: 750px;

  background-image: url(https://raw.githubusercontent.com/s1mpson/-/master/codepen/infinite-photo-grid/photo-grid.jpg);

  background-size: calc(4.84 * min(100vh, 750px)) min(100vh, 750px);

  background-repeat: repeat-x;

  animation: scroll 50s linear infinite;

}


@keyframes scroll{

  from {

    background-position: left calc(4.84 * min(100vh, 750px)) top 0px;

  }

  to {

    background-position: left 0px top 0px;

  }

}

</style>

 

<main class="infinite-photo-grid"></main>

 

결과보기

 

background-image 예제 - 이미지주소를 base64 코드 사용하기

 

  • background-image: url('data:image/png;base64,PNG_IMG_BASE64_CODE');
  • background-image: url('data:image/jpeg;base64,JPEG_IMG_BASE64_CODE');
  • background-image: url('data:image/gif;base64,GIF_IMG_BASE64_CODE');

 

PS. 자세한 내용은 <img> 태그 목차 12번 내용 참고.



분류 제목
position CSS - clear 속성 ★ - float 해제후 줄바꿈 (= 클리어속성, clear속성, 상속 X)
position CSS - display 속성 ★★★★★ - 요소유형지정 (= 요소성격변 = 요소노출방식 = display속…
position CSS - position 속성 ★★★ - 위치기준대상지정 (= 위치속성 = 포지션속성 = 위치조정 = po…
position CSS - top 속성 ★ - 기준상단 (= 위기준 상단거리 = top속성 = 탑속성/톱속성)
position CSS - right 속성 ★ - 오른쪽기준(= 우측기준) 위치 지정 (= right속성 = 라이트속성) ※…
position CSS - bottom 속성 ★ - 기준하단 (= bottom속성 = 하단기준 = 아래기준 = 바텀속성 = …
position CSS - left 속성 ★ - 왼쪽기준 (= left속성 = 좌측기준 = 레프트속성, 상속 X)
position CSS - z-index 속성 ★ - 요소층수지정 (= 요소상하지정 = 요소상하결정 = 위아래지정 = z-…
position CSS - visibility 속성 ★ - 보임설정 (= 노출설정 = visibility속성 = 비저빌러티속…
position CSS - overflow 속성 ★★ - 범위이탈요소처리 (= 범위넘는요소처리 = 스크롤바 생성 = over…
position CSS - clip 속성 (폐기예고) - 이미지 자르기 (= 일부만 노출 = clip속성 = 클립속성)
css CSS - cursor 속성 - 커서 모양 (= cursor속성 = 커서속성)
intro CSS - !important 키워드 - 당해 속성값 강제 우선적용 (= 우선순위표시 = 느낌표임포턴트)
css CSS - opacity 속성 - 불투명도 (= opacity속성 = 오패서티속성/오페서티속성) ※ 있는데 …
table CSS - border-collapse 속성★ - 테두리겹침설정 (= 테두리중첩설정 = 테두리이중방지 = b…
table CSS - border-spacing 속성 - 테이블셀 테두리간격 (= border-spacing속성 = 보…
table CSS - caption-side 속성 - 테이블표제위치 (= caption-side속성 = 캡션사이드속성)
css CSS - 글자자르기 (= 문자열자르기 = 문자열줄이기= 글자길이자르기 = 문자열자르기 = 글자수자르기 = …
css CSS - zoom 속성 - 요소 확대 (= zoom속성 = 줌속성) ※ IE 하위 브라우저(예: IE6, …
intro CSS - CSS3 입문
6/25
목록
찾아주셔서 감사합니다. Since 2012