a

[css] 마진 병합

마진 병합을 이해 못하는 사람들이 많다는 것에 간혹 놀랍니다. 단순히 마진을 내부 여백은 패딩과 비교하여 바깥 여백만으로 생각하면 문제가 심각해집니다. 마진 병합은 2개의 요소가 서로 이웃하여 만나는 경우, 하나의 마진인듯이 큰 값으로 적용됩니다. 

가령 3px의 마진을 가진 a,b 요소가 수직으로 만나게 된다면 둘 사이의 거리는 6px이 아니라 3px이 됩니다. 이것까지는 이해하지만 문제는 부모와 자식 요소 사이에 마진 병합 발생입니다.

부모와 자식사이에 발생된 마진 병합 처리는 구형 IE 브라우저는 제대로 처리 못합니다. 3px 마진을 가진 부모내에 5px의 마진을 가진 자식이 위치한다면 부모의 마진이 5px로 작동됩니다. 이것이 꽤나 기괴하게 보일 수 있고 또 브라우저에 무슨 오류난 것이 아닐까라는 착각도 하게 만듭니다. 그러나 이것은 어디까지나 제대로 작동되는 마진병합입니다.

자식의 마진은 부모의 마진을 변경시킬 수 있습니다. 자식의 마진이 10px이면 부모의 마진이 5px인데도 10px로 됩니다. 그러나 이러한 자식과 부모의 마진 병합 발생을 방지하려면 부모 요소에 padding이나 border 설정이 1px 이상 있으면 됩니다.




|

댓글 2개

그렇군요 ...*^^*
이런 심오한 이치가 숨어 있었군요....
댓글을 작성하시려면 로그인이 필요합니다. 로그인

퍼블리셔팁

퍼블리싱과 관련된 유용한 정보를 공유하세요. 질문은 상단의 QA에서 해주시기 바랍니다.

+
분류 제목 글쓴이 날짜 조회
HTML 14년 전 조회 3,189
HTML 14년 전 조회 3,211
HTML 14년 전 조회 3,010
HTML 14년 전 조회 3,717
HTML 14년 전 조회 2,843
HTML 14년 전 조회 4,174
HTML 14년 전 조회 2,209
HTML 14년 전 조회 3,553
HTML 14년 전 조회 2,978
HTML 14년 전 조회 3,165
HTML 14년 전 조회 3,113
HTML 14년 전 조회 2,761
HTML 14년 전 조회 4,048
HTML 14년 전 조회 4,581
HTML 14년 전 조회 3,893
HTML 14년 전 조회 4,470
HTML 14년 전 조회 3,249
HTML 14년 전 조회 2,324
HTML 14년 전 조회 2,672
HTML 14년 전 조회 2,216
HTML 14년 전 조회 2,806
HTML 14년 전 조회 2,598
HTML 14년 전 조회 2,625
HTML 14년 전 조회 4,776
HTML 14년 전 조회 3,825
HTML 14년 전 조회 6,456
기타 14년 전 조회 3,688
HTML 14년 전 조회 3,016
기타 14년 전 조회 4,332
HTML 14년 전 조회 2,995
🐛 버그신고