홈으로 | 무료회원가입 | 아이디/비번찾기
추천음악방송
익스플로러 버전별 CSS 적용방법
11년 전
첫번째 : IE버전별로 css을 따로 만들어 적용하는 방법

<link rel="stylesheet" type="text/css" href="default.css" />
< !--[if IE 7]><link rel="stylesheet" type="text/css" href="ie7Debug.css" /><![endif]-->
< !--[if IE 6]><link rel="stylesheet" type="text/css" href="ie6Debug.css" /><![endif]-->



두번째 : css파일안에서 구분해주는 방법

.selector { property:value; property:value; }
.selector { property:value; *property:value; } /* IE 7 이하의 브라우저에 작용 합니다 */
.selector { property:value; _property:value; } /* IE 6 이하의 브라우저에 작용 합니다 */




[설명]
IE : [if IE] - IE일 경우에만 처리한다.
IE 버전 : [if IE 7] - 해당 버전의 IE일 경우에만 처리한다. (5, 5.5, 6, 7, 8)
! : [if !IE]  IE가 아닐 경우에만 처리한다.
lt : [if lt IE 5.5]  IE버전이 5.5미만일 경우에만 처리한다.
lte : [if lte IE 6]  IE버전이 6이하일 경우에만 처리한다.
gt : [if gt IE 5]  IE버전이 5초과일 경우에만 처리한다.
gte : [if gte IE 7]  IE버전이 7이상일 경우에만 처리한다.
() : [if !(IE 7)]  조건을 결합하여 처리한다. IE버전이 7이 아닐경우에만 처리한다.
& : [if (gt IE 5)&(lt IE 7)]  조건을 AND로 결합하여 처리한다. IE버전이 5초과 7미만일 경우에만 처리한다.
| : [if (IE 6)|(IE 7)]  조건을 OR로 결합하여 처리한다. IE버전이 6 또는 7일 경우에만 처리한다.

참고> CSS HACK(핵)을 사용하는 법도 있다.



IE 버전별로 css 적용하기
ie 6에서만 적용하기

<!--[if ie 6]>

<style type="text/css">
html {
    overflow: scroll;
    overflow-x: auto;
}
</style>
<![endif]-->



<!--[if ie 7]>

<style type="text/css">....</style>

<![endif]-->



gt = selects greater than  보다큰 :  if gt IE 6 ->  현재버전 > 6
lt = selects less than 보다 작은 :  if lt IE 6 ->  현재버전 < 6
gte = selects greater than or equal to 같거나 큰  :  if gte IE 6 ->  현재버전 >= 6
lte = selects less than or equal to 같거나 작은  :  if lte IE 6 ->  현재버전 <= 6

ex) <!--[if gtie 7]><![endif]-->, <!--[if ltie 7]><![endif]-->, <!--[if gteie 7]><![endif]-->
, <!--[if lte ie 7]><![endif]-->


IE 코멘트 핵 소개
Tuesday, July 5, 2005
표준을 구연하는데에 쓰이는 해킹, 핵을 쓰는것이 CSS 이던 XHTML 부분이던 과연 좋은것인지 안좋은 것인지는 개개인의 판단과 기준에 따라서 바뀌는 부분입니다. 하지만, 아직 완벽하지 않은 표준의 태두리에서 그 태두리 안에 들어가기 위해서는 어쩔수 없는 부분일 수도 있겠습니다.

핵 사용의 정당성
WebGraphics는 이렇게 정의합니다

A hack is a way to fool browsers.
-핵은 브라우저들을 놀리는 방법이다. (각 브라우저가 어떤부분이 약한지를 알아서 그 부분을 꼬아서 편법을쓴다고 해석할수 있슴)
A workaround is a way to fool rendering problems, and minimize the affected browsers.
-workaround, 즉 막노동, 뺑 돌아가는 일을 사용하여 렌더링 문제를 꼬는 방법으로 영향받는 브라우저가 적게한다. (CSS 자체가 어떻게 행동하는지를 더 자세히 코딩하여 제어함으로 브라우저가 읽을시에 오해가 적도록 하게하는법. 예로 3+2=5 라고 표현하는 부분이 오해가 생길만 하다면 1+1+1+1+1=5 라고 지정해 주는것이 되겠슴)

그리고 WebGraphics 블로그에서는 3가지 과정을 통해 핵을 사용하도록 권하더군요.

If we know a bug, we can sometimes prevent it - 버그를 알고 있으면 가끔은 미리 예방을 할수 있다.
If it isn’t possible, we can use a workaround - 그것이 가능치 않다면 막노동이지만 더 자세히 표현하여 막는다.
If we tried everything without success, we can use a hack - 이 모든것들을 해 보아도 되지 않을시에 비로소 핵을 고려해 본다.
제가 여러포스팅을 통해 CSS 핵을 소개해 드렸지만 workaround 될만한 것들도 나눌수 있었으면 좋겟네요. 참 많이 배우고 느낄만한거 같습니다. 일단 핵의 사용과 그것의 목적등을 나누고 싶었습니다.

아무튼 이번것은 workaround가 아닌 핵입니다만, 이것은 css 핵이 아닌 xhtml 핵입니다. 마이크로소프트에서 이 부분이 가능하도록 배려(?) 해주었네요. 기본 형식은 이러합니다.

IE 핵의 기본형식
.

<!--[if IE]>
<link type="text/css" media="screen" href="style.css" />
<! [endif] -->“IE 일때는 style.css 를 읽어라” 라는 뜻입니다. 아시다시피 xhtml 의 코멘트는 <!– 으로 시작합니다. 그리고 코멘트가 끝날때에는 –> 로 끝이나죠. 이 사이에 [if IE], [endif] 등을 넣어서 핵으로 인식되도록 하는 방법입니다.

<!--[if IE]>
<style type="text/css">
  #content { width: 550px;}
</style>
<![endif]-->IE는 박스모델의 문제가 있으니 IE에서만 읽을수 있도록 content 라는 id 의 div 를 550px 로 설정해 준 부분입니다. 물론 이부분은 xhtml 안에 들어가는 부분입니다.

저것은 모든 IE 를 통틀어 지정해 주는 부분이고 버전에 따라서 지정을 해줄수 있습니다.

IE 버전에 따라 지정
IE 바로 다음에 버전을 넣어주면 됩니다

<!--[if IE 5.0]>
<h3>THIS IS IE 5.0</h3>
<![endif]-->위의 <!–[if IE 5.0]> 부분에 IE 뒤에 5.0 이 버전을 나타냅니다. 6.0 이 될수도 있고, 5.5 도 될수 있겠네요. “THIS IS IE 5.0″ 부분은 인터넷익스플로러 5.0 에서만 보입니다.

IE 의 특정 버전만 선택하지 않기
불린Boolean 의 ! 느낌표를 써주어 부정을 넣을수 있습니다.

<!--[if !IE 5.0]>
<h1>모든 브라우저에서 보이지만 ie5.0에서만 안보입니다.</h1>
<![endif]-->if IE 사이에 느낌표 ! 가 들어가서 if !IE 가 되면 뒤에나온 버전만 빼달라는 것입니다.

IE 버전들을 포괄적으로 선택하기
버전들을 포괄적으로 선택이 가능합니다. 버전 5.5 이상, 버전 6.0 이하 이런식으로 말이죠. 그리 어렵지는 않습니다.

<!--[if  gte IE 5.5]>
<style type="text/css">
   .h2 { font-size: 1.2em;}
</style>
<![endif]-->gte 라는 부분이 IE 와 버전 사이에 들어가 있습니다. if 구문 다음에 들어갔습니다. 이 gte 는 “Greater Than or Equal to” 를 줄인것으로 이상 을 뜻합니다. 즉 5.5 도 포함해서 그 이상이죠. 이 말고도 gt, lt, lte 가 있습니다.

gt greater than - 그보다 높은버전 if IE gt 5.0 은 5.0보다 높은, 5.1부터 그 이상
gte greater than or equal to-그 이상. if IE gte 5.0 은 5.0을 포함한 그 이상.
lt less than - 보다 낮은 버전. if IE lt 6.0 - 6.0보다 낮은 버전들. 5.5 5.0등
lte less than or equal to - 그 이하버전 if IE lte 5.5 - 5.5을 포함한 이하버전

버전을 직접 정하는 것보다 이렇게 포괄적으로 선택하는것이 더 나은 방법일겁니다. 특히 3px 버그나 박스모델 버그는 <!–[if lte IE 5.5]> 를 써 주어 5.5 이하버전들을 선택해 주면 되겠네요.

표준을 위한 핵. 그것은 편법입니다. 편법을 많은곳에서 사용은할수 있지만 권장하는 방법은 아닙니다. 하실수 있다면 그 문제를 돌아서 가더래도 핵이아닌 방법으로 해결하시면 좋겠습니다. padding 보다는 margin 의 사용을 늘린다던지 하는 방법이 그리합니다.
추천추천 : 562 추천 목록
번호 제목
3,036
 PHP 함수 정리
3,035
 아이프레임(iframe) 비율 유지하면서 크기 조절하는 방법
3,034
 PHP 배열에서 무작위로 하나 뽑아주는 array rand() 함수
3,033
 PHP 정규식 정리
3,032
 PHP 정규식을 활용한 태그 및 특정 문자열 제거 및 추출 방법
3,031
 php 크롤링 또는 파싱 함수, 정규식 모음
3,030
 제이쿼리 기본 명령어
3,029
 웹페이지 가로 모드세로 모드 인식하기
3,028
 모바일 웹 화면 강제 회전(가로모드 고정)
3,027
 [HTML5]에서 frameset 대체 방법과 iframe 속성
3,026
 HTML <Audio> 사용법
3,025
 윈도우10 시스템파일 손상 (초간단 오류 복구방법!!)
3,024
 PHP 파일 존재 여부 파악하기(로컬 파일 존재 및 원격지 파일 존재)
3,023
 [CSS] 박스 세로 가운데 중앙 정렬 6가지
3,022
 CSS Layout 수평 & 수직 정렬
3,021
 여러 도메인들 간 쿠키 공유하기
3,020
 태그 사이에 있는 텍스트를 추출
3,019
 [JQuery] textbox focus on off일때 숫자 콤마 보여주기
3,018
 쿠키 생성,가져오기,삭제
3,017
 사용자 함수 모음
3,016
 마우스,키보드 제한 ( 오른쪽클릭,드래그,영역선택등..)
3,015
 [HTML5] <video> - DOM으로 제어하기
3,014
 HTML5 video 태그에서 영상 좌우반전
3,013
 PHP - 특정 태그 및 문자열 추출, 제거
3,012
 [PHP] define과 defined의 차이
목록
뮤직트로트 부산광역시 부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.