CSS Collapsing margins การยุบรวมกันของ margins ใน CSS

แรกเริ่มเดิมทีนั้น ผมตั้งใจเขียนบทความเรื่อง CSS Basic box model แต่บังเอิญดันไปติดเรื่องความยากในการอธิบายในเรื่องของ Margins ซึ่งอาจจะทำให้บทความยาวไปถึง เบตง ได้ จึงตัดตอนเอาเรื่อง margins ออกมาก่อน แล้วค่อยเขียนเรื่อง box model คงทำให้หนุ่มสาวทั้งหลายเข้าใจง่ายยิ่งขึ้น

อะไรเอ่ย ที่ทำให้เราเกิดการ “งุนงง” ในชีวิตเป็นอย่างมาก เมื่อการเขียน CSS สั่งงาน HTML แล้วมันไม่ทำตาม เฉกเช่นเดียวกับการใส่ margin ให้กับ element ที่เราต้องการแต่ดันไม่แสดงผล

เราไม่ได้เขียน CSS ผิดแต่ประการใด ไม่เลย เราไม่ได้เขียนผิด แต่เป็นแค่เพียงเราไม่เข้าใจ กฎ บางข้อของ CSS เท่านั้นเอง ถ้าใครเข้าใจแล้วก็ ข้ามไปเลยนะขอรับ

หรืออาจเป็นเพราะเราเสพดราม่า มากจนเกินไป (ผมก็ติด)

หนุ่มสาวเอย จงมาเสพ margins ให้กระจ่างโดยพลัน

การยุบรวมกันของ Margins มันคืออะไรวะ มันยุบรวมกัน หรือมันรวมตัวกันได้ด้วยหรือ การรวมกันมันเหมือนที่ พธม. หรือ นปช. รวมกันไหม โอ้ว ช่างหลายหลากคำถามเหลือเกิน

กฎการยุบรวมกันของ Margins (ของแม่กับลูก)

  1. เฉพาะ Block-level เท่านั้นที่จะใช้กฎการยุบรวมกันของ margins ได้
  2. กล่องที่มี การ float หรือ มี position เป็น absolute จะไม่ยุบรวม
  3. กล่องที่มี overflow และหรือ visibility จะไม่เกิดการยุบรวมกันของ Margins กับ Child element ของมันเอง
  4. inline-block จะไม่เกิดการยุบรวม เพราะไม่ใช่ block-level (อยู่ก้ำกึ่งระกว่าง inline และ block)
  5. root element จะไม่ยุบรวม (<html>)

กฎข้างบนนั้นหมายความว่ายังไง เรามาดูกัน ในตัวอย่าง

HTML

การแสดงผล

ตังอย่างการ ยุบรวมกันของ Margin

เรามาดูว่า margin ของแต่ละ element นั้นมันรวมตัวกันยังไงบ้าง

  • พื้นที่ สีส้มด้านบน อันแรก ที่เห็นนั้นคือ พื้นหลังของ div.margins พื้นที่ว่างตรงนี้เกิดจากการรวมกันของ
    1. margin-bottom ของ p ที่เป็นลูกตัวแรกของ .margins
    2. margin-top ของ div ที่เป็นน้องของ p ด้านบน
    3. margin-top ของ p ที่เป็นหลานตัวแรกของ .margins
    4. ถ้าไม่เกิดการยุบรวม พื้นที่ตรงนี้จะมีระยะห่างเป็น 30+30+30+30 = 120px แต่เมื่อยุบรวมกันแล้วทำให้เหลือพื้นที่ห่าง 30px
  • พื้นที่ สีน้ำเงิน คือ พื้นหลังของ .margins div {} คือ div ที่เป็นลูกของ .margins
  • ถึงแม้ว่า เราจะเขียน .margins p, .margins blockquote { margin: 30px 0;} และ .margins div { margin: 10px 0 40px 0;} element ทั้งหมดที่มี margins นั้น จะนำ margin มารวมเข้าด้วยกันแล้วเลือกใช้ค่าที่มากที่สุด เช่น p ที่เป็นลูกตัวแรกของ div.margins จะเอา margin-top ไปรวมกับแม่ของมัน แล้วเอา margin-botom ไปรวมกับ div ที่อยู่ถัดไป (div ที่เป็นน้อง)

กฎข้อที่สำคัญที่สุด ที่มีผลต่อการเขียนหน้าเว็บอยู่ตรงนี้ คือ “การยุบรวมของแม่กับลูกจะไม่เกิดขึ้น ถ้ามี border หรือ padding มากั้นเอาไว้”

จะเกิดอะไรขึ้น ถ้าผมใส่ padding: 1px 0; ให้กับ .margins div

การแสดงผล

เพิ่ม padding ให้กับ element

เมื่อเราเพิ่ม padding: 1px 0; ให้กับ div ที่เป็นลูกตัวที่ 2 ของ .margins จะทำให้ p ที่เป็นหลานตัวแรกของ .margins แสดงค่า margin-top ออกมา และทำให้ p ที่เป็นหลาน ตัวที่ 3 (ถัดจาก blockquote) นั้นแสดง margin-bottom ออกมา

ที่กล่าวมานั้น คงพอทำให้คนที่สงสัยว่า ระยะห่างด้านนอกของกล่องที่เราใส่เข้าไปนั้นมันหายไปไหน ได้บ้างแล้วนะครับ

บทความนี้คงเขียนเอาไว้แค่นี้ครับ เขียนมากเดี๋ยวความหน้าจะไม่มีเรื่องเขียน -*-

หมายเหตุ

  1. block-level คือ Element ที่ถูกสั่งให้ display เป็น block ซึ่งเป็นคนละความหมายกับ Block element เพราะ span สมารถสะดีดสะดิ้งเป็น block-level ได้ ถ้าเราสั่งให้มันเป็น
  2. ยังมีเรื่องสำคัญอีกอย่างของการยุบรวม ที่ผมไม่ได้พูดถึงคือ sibling (พี่น้อง) จะยุบรวมเสมอ ยกเว้น กรณีของการ float และ clear มันจะ ยุบๆ ขยายๆ อยากให้ไปลองทำกันดูครับ
รักกันชอบกันอย่าลืมแชร์นะครัช:
error0
Tweet 20
fb-share-icon20

Back to Top

5 Responses to CSS Collapsing margins การยุบรวมกันของ margins ใน CSS

  1. pookpik

    ขอบคุณสำหรับบทความดีๆ มีประโยชน์มากๆ เลยค่ะ

    Reply

  2. sssx

    กำลังศึกษา css อยู่ แบบงงๆๆ

    ขอบคุณสำหร้ับบทความนะครับ

    Reply

  3. Noboyband

    บทความมีประโยชน์อ่านแล้วเข้าใจได้ง่ายขึ้นมากเลยครับ ขอบคุณครับ

    Reply

Leave a Reply to Sitthiphorn Anthawonksa Cancel reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.

Back to Top

Social Share Buttons and Icons powered by Ultimatelysocial