การจัดการกับความสูง

สำหรับคนที่ได้ลองเขียน css ด้วยตัวเองมาบ้างแล้ว ก็คงพอจะทราบว่า แท้จริงแล้ว หน้าเว็บก็ไม่ได้มีอะไรมากไปกว่าการทำกล่องและใส่ margin padding ซึ่งก็คือ การจัดตำแหน่งการแสดงผลของหน้าเว็บเพจ โดยใช้โค้ดที่แยกออกจากส่วน โครงสร้าง HTML เท่านั้นเอง แต่ภายใต้การกระทำที่แสนจะพื้นฐาน กลับมีเทคนิคมากมาย เพราะเบราเซอร์ที่มีในโลกนี้ ไม่ได้ทำงานไปในทิศทางเดียวกัน หากเขียน css ให้เว็บเพจดูได้สมบูรณ์ที่ เบราเซอร์เดียวแล้วละก็ เราจะไม่ต้องมีเทคนิคอะไรเลยก็ทำได้ง่ายแสนง่าย  ดังนั้นเมื่อเริ่มเขียน css สิ่งที่ควรจะระลึกไว้เสมอคือ ถ้าต้องการให้เว็บดูได้สมบูรณ์ที่ หลายๆเบราเซอร์ อย่าใช้โค้ดใหม่ (css2 , css3) หรือโค้ดเทพต่างๆให้มากนัก เพราะคุณจะประสบปัญหาการแสดงผลอย่างแน่นอน แล้วจะต้องมานั่ง hack กันให้เสียเวลา  พยายาม keep simple เข้าไว้ หรือถ้าคุณไม่แคร์ และคิดว่า จะให้เว็บดูสุดยอดที่ firefox เท่านั้น นั่นก็อีกเรื่อง ใส่กันเข้าไปให้เต็มที่ ตามใจอยาก

เข้าเรื่องที่จะพูดถึงกัน เว็บเพจโดยทั่วไปแล้ว มักจะถูกกำหนดความกว้าง (width) เป็นค่าอย่างใดอย่างหนึ่ง อาจเป็น pixel หรือ เปอร์เซ็นต์ เพราะเราไม่ต้องการให้มีการยืดที่ด้านข้าง แต่เว็บเราเลื่อนลงข้างล่าง ความสูง(height) จึงมักจะเป็นตัวแปรตาม คือไม่กำหนดค่า แล้วแต่ว่า เนื้อหาภายในมีมากน้อยเพียงใด เรามาดูว่า ปัญหาของค่า height นั้นมีอะไรบ้าง

เริ่มด้วยด้วยโค้ดง่ายๆ โดยมี doctype ตามภาพ

 html1.gif

การแสดงผลของ .aa ยังเหมือนกันทั้ง IE6 Fx2.0  เมื่อพิมพ์ตัวหนังสือมากขึ้น โดยเว้นบรรทัด แถบสีเขียว ก็ยืดตามลงมาไม่มีปัญหาแต่อย่างใด

เริ่มกำหนด height

ใส่ค่า height ดังนี้

.aa{width:300px; background:#CCCC00; height:7px}

ผลที่ได้

height1.gif

เมื่อเอาตัว a ออก ผลที่ได้ยังเหมือนเดิม Firefox ทำงานอย่างเถรตรง ตามค่าที่กำหนด   IE ไม่สามารถ กำหนดความสูง ที่ต่ำกว่า ค่าความสูงของ font ที่กำหนดได้ อีกทั้งยังขยายใหญ่ตาม font-size อีกด้วย หากเรากำหนด font-size ให้มีขนาดใหญกว่าปกติ แถบสีเขียวจะใหญ่ตาม ในที่นี้ font-size ไม่ได้ถูกกำหนดไว้ ค่า default ในส่วน body คือ font-size= 16px ดังนั้น ความสูงของ div ที่เล็กที่สุดที่ IE 6 จะได้ทำได้อยู่ที่ประมาณ 19px (รวมระยะห่างโดยรอบ)

นั่นหมายความว่า IE6 ไม่สามารถทำ div อันเล็กๆอย่าง 5×5 px  หรือ 10×10 px ได้  แต่ในเมื่อเรารู้ตัวแปรต้นแล้ว การควบคุมตัวแปรตามย่อมทำได้ ดังนั้นเราก็กำหนดเพิ่มดังนี้

.aa{width:300px; background:#CCCC00;height:7px; font-size:1px}

ผลที่ได้คือ เราจะได้ div ที่ height 7 px เหมือนกันทั้ง IE6 Fx

ความรู้ตรงนี้นำไปใช้อะไรได้บ้าง?  ก็เอาไว้ทำ div เล็กๆสำหรับใส่แบ็คกราวน์ภาพเช่น ทำสี่เหลี่ยม ขอบโค้ง

cbox.gif

ขอบโค้งบนล่าง มีความสูงแค่นิดเดียว ถ้าเราทำ div แบบปกติ แล้วใส่แบ็คกราวนด์ รับรองว่าจะเกิดช่องว่างแน่นอน(IE6) การทำกล่องขอบมนแบบต่างๆจะ กล่าวถึง ในโอกาสต่อๆไป :)

กำหนดความสูงสำหรับกล่องเนื้อหา

เขียนโค้ด css และ html ดังนี้

<style type=”text/css”>
.aa{width:150px; background:#CCCC00; height:150px;}
</style>

<div class=”aa”>divland.com<br />
<br />
<br />
<br />
เว็บไซต์ css เล่า<br />
จากประสบการณ์จริง<br />
<br />
เจอปัญหา<br />
มีวิธีแก้แล้วเอามาเขียน<br />
</div>

จะได้ผลลัพธ์แบบนี้

height2.gif

เห็นความแตกต่างกันชัดเจน IE6 ยืดตามลงมาให้ แต่ Fx สูงตามที่กำหนด
ในกรณีที่เราไม่ต้องการให้กล่องเล็กกว่า 150px เราจึงต้องกำหนดค่า height แต่ขณะเดียวกัน ก็ต้องการให้มันยืดตามเนื้อหาด้วย เราเปลี่ยน css ใหม่ดังนี้

.aa{width:150px; background:#CCCC00; min-height:150px;}

min-height ก็คือ สูงอย่างน้อย  เมื่อกำหนดแบบนี้ Fx จะยืดลงมาเหมือน IE6 แล้ว แต่ถ้า เราลด text  ให้สั้นลงล่ะ
จะได้แบบนี้

height3.gif

นั่นเป็นเพราะ IE6 ไม่รู้จัก property min-height เอาไงดีล่ะ IE6 ต้องใช้ height  แต่ Fx ต้องใช้ min-height ถ้ากำหนด ทั้ง 2 ตัวพร้อมกันเลย Fx ก็จะถูกค่า height กักไว้ ไม่ให้ยืดอยู่ดี  เมื่อเป็นแบบนี้ เราก็นึกถึงการ hack ขึ้นมาล่ะ เราก็เขียน height หรือ min-height ไปก็ได้ แล้ว hack เบราเซอร์ที่เหลือแทน วิธีการ hack ก็ตามนี้ที่เราได้รู้มา

แต่วิธีที่ผมชอบใช้ก็คือเขียนให้อยู่ที่เดียวกันไปเลย โดยใช้ ความรู้เรื่อง !important เข้ามาช่วย เรารู้มาว่า IE6 ไม่ให้ความสำคัญกับ !important อย่างที่ควรจะเป็น (จาก cascading order) ดังนั้นผมจะเขียนแบบนี้

.aa{
width:150px;
background:#CCCC00;
height:auto!important;     /* Fx อ่านบรรทัดนี้ เพราะมี !important */
height:150px;            /* IE6 อ่านบรรทัดนี้ เพราะไม่สน !important อ่านบรรทัดล่างสุด ตามกฎปกติ*/
min-height:150px    /*Fx และเบราเซอร์ใหม่ๆ อ่านบรรทัดนี้ */
}

แปลเป็น ภาษามนุษย์ก็คือ กล่องนี้จะสูง auto ตามเนื้อหา แต่สูงอย่างน้อย 150px  ส่วน IE6 ก็กล่องนี้ สูง 150 px

ความสูงของกล่องเมื่อมีการ float ข้างใน

จากโค้ด css และ html ดังนี้

.aa{width:300px; background:#CCCC00;padding:10px;}
.bb{width:100px; height:100px; float:left; background:#f2f2f2}
.cc{width:100px; height:100px; float:right; background:#f2f2f2}

<div class=”aa”>
<div class=”bb”></div>
<div class=”cc”></div>
</div>

จะได้ผล ดังนี้

height4.gif
float แปลว่า ลอย เมื่อมันลอยอยู่ ขอบของ div ตัวนอก จึงไม่ถูกดึงลงมา วิธีแก้มีอยู่ 2 วิธี

1. คือ ใช้ clear  เขียน class เพิ่ม ดังนี้

.clear-all{clear:both; height:0; line-height:0}

แล้วเพิ่ม ไปในส่วน html ดังนี้
<div class=”aa”>
<div class=”bb”></div>
<div class=”cc”></div>
<br class=”clear-all” /> หรือ <div class=”clear-all”> </div>
</div>

2. คือ ใส่ overflow:hidden ที่ div ตัวนอก

.aa{width:300px; background:#CCCC00;padding:10px; overflow:hidden}

ก็จะได้การแสดงผลที่ถูกต้องทั้ง 2 เบราเซอร์

Related posts

11 Comments »

  1. googiw said,

    August 1, 2007 @ 9:27 am

    ได้ความรู้เพิ่มเยอะเลย หุหุ
    ขอบคุงคะ :)

  2. เมโกะ said,

    August 11, 2007 @ 8:30 pm

    พยามโพสต์หลายครั้งแต่ไม่เข้า ดูไปดูมาอ๋อเราโง่นี่เอง อิอิ ทึ่งมากกับฝีมือของพี่ สีสวยและมากด้วยสาระ อ่านสนุก ขอเป้ฯกำลังใจให้ค่ะ

  3. เมโกะ said,

    August 11, 2007 @ 8:37 pm

    วันนี้พาแขกมาเยี่ยมเว็ปพี่คนนึงค่ะ พี่มารน้อยอาจารย์สอนโอเทลโลของนู๋เอง เค้าเคยเล่นกับพี่ด้วย เขาบอกว่าหาเว็ปแบบนี้มานานแล้ว เขาอยากรู้จักพี่ค่ะ บอกว่าอยากรู้จักคนเก่งๆ ขอชื่นชมๆ

  4. ปีโป้ said,

    August 17, 2007 @ 7:19 pm

    ขอถามหน่อยค่า แล้วถ้าหากเรามีกล่อง 1 กล่องใหญ่ แล้ว มีกล่องเล็ก ข้างใน 2 กล่อง กล่องซ้าย มีข้อมูลเพียบ แต่กล่องขวา มีข้อมูลน้อยนิด

    ความสูงของกล่องขวา มันไม่ยืดตามกล่องซ้าย ทำไงดีอ่ะ มีวิธีป่าว ถ้าอยากให้ความสูงของกล่องขวายืดตามกล่องซ้ายอ่ะ:-w

  5. utt said,

    August 18, 2007 @ 3:14 am

    ทำไม่ได้ด้วย CSS ครับ กรณีนี้ต้องใช้ javascript ช่วยครับ คือคำนวณความสูงของกล่องที่สูงสุดแล้วใช้ innerhtml เขียนเข้าไปใน กล่องอีกอัน :)>-

  6. admin said,

    August 19, 2007 @ 12:03 am

    เดิมที ปัญหานี้ จะมี javascript ตัวหนึ่ง เอาไว้แก้โดยเฉพาะ ซึ่งที่ทำงานผมใช้กันอยู่ แต่จากที่ผมลองใช้ css เพียงอย่างเดียว และค้นคว้าจากเว็บต่างๆ คิดว่าทำได้ครับ แต่ก็ต้องใช้ property expression คือ ฝัง จาวาสคริปลงไปใน css แล้วจะเขียนเป็น tutorail อธิบายอีกทีละกันครับ คงจะยาวมาก ขอบคุณ ปีโป้ ที่จุดประกายความคิด ครับ :x

  7. likhi1 said,

    August 31, 2007 @ 12:42 am

    “แปลเป็น ภาษามนุษย์ก็คือ กล่องนี้จะสูง auto ตามเนื้อหา แต่สูงอย่างน้อย 150px ส่วน IE6 ก็กล่องนี้ สูง 150 px”

    ขอบคุณท่านพี่ที่แปลเป็นภาษามนุษย์ให้ครับ …. 5555:d:d:d:d

  8. sangsood7 said,

    September 3, 2007 @ 3:57 pm

    ขอบคุณมากครับ

  9. SexZero said,

    November 11, 2007 @ 10:56 pm

    ปีโป้ said,
    August 17, 2007 @ 7:19 pm

    ขอถามหน่อยค่า แล้วถ้าหากเรามีกล่อง 1 กล่องใหญ่ แล้ว มีกล่องเล็ก ข้างใน 2 กล่อง กล่องซ้าย มีข้อมูลเพียบ แต่กล่องขวา มีข้อมูลน้อยนิด

    ความสูงของกล่องขวา มันไม่ยืดตามกล่องซ้าย ทำไงดีอ่ะ มีวิธีป่าว ถ้าอยากให้ความสูงของกล่องขวายืดตามกล่องซ้ายอ่ะ

    ตอบ
    ให้ลองทำแบบนี้นะครับ
    1. ให้เราสร้างกล่องใบใหญ่ขึ้นมาใบนึงใน css สมมุตยกตัวอย่างชื่อ #content-container-three-column โดยกำหนดให้ค่าของมันคลุมทั้งหมด
    2. แล้วให้เราสร้างกล่องเล็กๆ ขึ้นมา 2 ใบ สมมุตตั้งชื่อว่า #content-left-three-column และ #content-right-three-column แล้วกำหนดให้อยู่แค่ ซ้าย กับ ขวา
    3. แล้วให้ประกาศใน html ไปว่ากล่องเล็กๆ 2 ใบนี้เป็นลูกของกล่องใบใหญ่อีกทีนึง

    ตัวอย่าง css Code :

    #content-container-two-column {
    margin-top:3px;
    margin-left:auto;
    margin-right:auto;
    padding:15px;
    width:600px;
    border:1px solid #818181;
    position:relative;
    }
    #content-right-two-column,
    #content-left-two-column {
    width:160px;
    }
    #content-right-two-column {
    float:right;
    }
    #content-left-two-column {
    float:left;
    }

    หลังจากนั้นก็ให้เขียนโค้ดใน html ดังนี้

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

  10. SexZero said,

    November 11, 2007 @ 11:09 pm

    จากตัวอย่างนี้

    .aa{width:300px; background:#CCCC00;height:7px; font-size:1px}

    ถ้าเราใช้ขนาดฟอนด์ 1 พิเซลบางทีมันอาจจะมีปัญหาเรื่องการแสดงฟอนด์โดยเราไม่รู้ตัวได้คับ เพราะมันจะไปทำงานกับไฟล์ html แล้วถ้าเกิดเราเผลอลืมไปใช้ฟอนด์ตัวนั้นหรือจะจัดระบบของ css ในอนาคตลำบากคับ
    ผมมีเทคนิคคิดว่าน่าจะใช้ได้แทนการใช้ font-size:1px ได้นะครับ

    คือให้เราเขียนใน html โดยใช้ คำสั่ง div แล้วเว้นวรรคมันซะ

     

    ยกตัวอย่างเช่น

    ©2007-2009 Divland.com all right reserved

     

    ลองทำดูนะคับ ผิดถูกยังไงบอกด้วยคับ

  11. SexZero said,

    November 11, 2007 @ 11:13 pm

    เวรกำ ผมเขียนโค๊ดไปแล้วดันหายไปกะตา คิดว่ามันประมวลผลให้เสียอีก ไม่พิมพ์ใหม่แล้วนะคับ ขี้เกียจและ ลองค้นหาในกูเกิ้ลกันดูนะครับ รับรองมีแน่นอนคับ

RSS feed for comments on this post · TrackBack URI

Leave a Comment

:) :( :d :"> :(( \:d/ :x 8-| /:) :o :-? :-" :-w ;) [-( :)>- more »

IDOL Beautifulidol.com WAZCOOL Wazcool.com ASTORE Astoreblog.com
MUSIC Hfonemusic.com POST Postigg.com LOAD uploadtoday.com