ทำ layout ให้สูงเท่ากัน ทุกคอลัมน์

จากตอน “การจัดการกับความสูง” ได้มีคอมเม้น ของคุณปีโป้ ได้เข้ามาถามไว้ว่า จะทำ กล่องที่มีเนื้อหาไม่เท่ากัน ให้สูงเท่ากันได้อย่างไร ถ้าจะตอบแบบ ไม่ต้องคิดมาก ก็คือ ใช้ table สิ เหอๆๆ แต่ ถ้าคนเคยทำ css แล้วจะมีอาการโรคจิต ชนิดหนึ่ง ที่จะต้องพยายาม ทำทุกอย่างในหน้าเว็บ โดยไม่ใช้ table ให้ได้ ราวกับว่า การมี table สักอันอยู่ในหน้าเว็บ เป็นความพ่ายแพ้ และเป็นที่เหยียดหยามอย่างมาก จากเพื่อนร่วมงาน ดังนั้นเรามาดูวิธี ทำโดยไม่ใช้ table แต่ทำแบบ table เอ๊ะยังไง????

table แบบเดิมเราเขียนกันแบบนี้

table.gif

 

เวลาเขียน ก็เขียนให้มันเรียงลงมา ปกติ ไม่ต้องไปพยายามเรียงซ้ายไปขวาแบบนี้ล่ะ ทำภาพให้ดูง่ายเฉยๆ ภายใน <table> ก็จะประกอบด้วย <tr> = table row และใน 1 <tr> ก็จะประกอบไปด้วย <td> = table data cell ดังนั้นเราจะเขียน css ตามรูปแบบนี้กัน
เขียน html ดังนี้

<div class=”equal”>
     <div class=”row”>
          <div class=”one”>
             aaa<br><br>
            divland.com layout
            <br><br>
             equal height
          </div>
          <div class=”two”>
             bbb
          </div>
          <div class=”three”>
             ccc
          </div>
     </div>
</div>

เขียน css ดังนี้

.equal {
    display:table;
 width:600px;
 border-spacing:10px;
 background:#f2f2f2;
}
.row {
    display:table-row;
}
.row div {
    display:table-cell;
 background:#CCCC00;
 }
.row .one {    
width:200px;
}  
.row .two {    
width:200px;
}
.row .three {    
width:200px;
}

ส่วนนอกสุด คลาส .equal  ใส่ property  display:table  ถัดมาเป็น .row display:table-row  ส่วน .row div ก็คือ div ทุกตัวที่อยู่ใน .row ให้เป็น display:table-cell   จะได้ รูปร่าง แบบนี้

table_cell.gif

โอ้วว มันยืดตามกันแล้ว  เหอๆ แต่มันได้เฉพาะ เบราเซอร์ในตระกูล Mozilla Firefox นะครับ Opera ก็น่าจะได้  ส่วน IE ก็เหมือนเดิมครับ ไม่สามารถ อ่าน property display ทั้ง  3 ตัวนั้นได้   ดังนั้นแล้ว เราจึงต้องมีโค้ดพิเศษสำหรับ IE6 และ IE7

โดยใช้ Conditional comments for IE  

    <!–[if IE]>
<style type=”text/css”>
    .equal {
padding-bottom: 10px;
}

.row {  
padding:10px;
}

.row div {
float:left;
}

.row .one {   
width:190px;
}
.row .two {   
margin-left:10px;
width:190px;
}
.row .three { 
width:190px; 
margin-left: 10px; 
}

* html .row div { /* IE6 and older */
height: expression(parseFloat(row.offsetHeight)-10);
}

html>body #row div { /* IE7, and maybe later versions */
min-height: expression(parseInt(row.offsetHeight)-43);
}
</style>
<![endif]–>

โค้ดด้านบนนี้จะถูกอ่านเฉพาะใน IE เท่านั้น  หลักการก็ไม่มีอะไร มาก จับ กล่อง  float:left แล้วใส่ margin ให้มีระยะ ห่าง ปัญหาคือความสูงที่ต้องยืดตามกัน  ก็ถูกคำนวณด้วย property expression คือใช้ตัว จาวาสคริป เข้ามาช่วยในการคำนวณ ความสูง ของกล่อง

* html .row div { /* IE6 and older */
height: expression(parseFloat(row.offsetHeight)-10);
}

โค้ดส่วนนี้ จะถูกอ่านที่ IE6 และ ต่ำกว่า ค่า -10 สามารถเปลี่ยนแปลงได้ ในกรณีนี้ผมใช้ ระยะห่างแต่ละกล่องที่ 10 px ลองเปลี่ยนค่าแล้ว พรีวิว ดู ถ้าหากคุณใช้ระยะห่างเป็นอย่างอื่น

html>body #row div { /* IE7, and maybe later versions */
min-height: expression(parseInt(row.offsetHeight)-43);
}

โค้ดส่วนนี้ถูกอ่านที่ IE7 และเวอชั่นสูงกว่า  คำนวณค่าความสูงเช่นกัน ปรับค่า ข้างหลังได้

ในส่วนของโค้ด IE นั้น จะเห็นว่า ตรงบรรทัดของ IE7  จะมีการใช้ #row  ดังนั้นเราจะต้องเพิ่มส่วนของ html ด้วยดังนี้

<div class=”equal”>
  <div id=”row” class=”row”>
  <div class=”one”>
  aaa<br><br>
  divland.com layout
  <br><br>
  equal height
  </div>
  <div class=”two”>
  bbb
  </div>
  <div class=”three”>
  ccc
  </div>
  </div>
</div>

เท่านี้ก็จะได้ คอลัมน์ ที่สูงเท่ากัน แม้ว่าเนื้อหาไม่เท่ากัน
***** จะใช้ได้ กรณี ที่มีแถวเดียวเท่านั้นนะครับ ถ้าคุณเพิ่ม กล่องอีก 1แถว ใน IE จะผิดพลาดทันที เพราะมีการคำนวณโดยใช้ id มันจะสับสน ถ้าหากมีมากกว่า 1 เพราะฉะนั้น ใช้ในการทำ layout เท่านั้นนะครับ

ลองดูไฟล์ตัวอย่างได้ที่นี่ครับ  css-layout-equal-height.html

Related posts

10 ความเห็น »

  1. likhi1 said,

    กันยายน 10, 2007 @ 9:04 pm

    “ปัญหาคือความสูงที่ต้องยืดตามกัน ก็ถูกคำนวณด้วย property expression คือใช้ตัว จาวาสคริป เข้ามาช่วยในการคำนวณ ความสูง ของกล่อง ”

    อยู่ไหนอ่ะตัว javascript ???
    อ่านแล้วงงๆ สงสัยต้องลองทำ….ไว้ว่างๆอ่ะ

    ปล. บทนี้ยากแฮะ

  2. chan said,

    กันยายน 11, 2007 @ 9:10 am

    เยี่ยมมากๆครับ หามานานแล้ว วิธีนี้:”>:”>

  3. Dech said,

    กันยายน 11, 2007 @ 1:18 pm

    It’s so great :d Thanks.:)>-

  4. Petch said,

    กันยายน 13, 2007 @ 11:17 am

    ช่วยอธิบายเรื่องนี้ให้ชัดเจนหน่อยคับ ผมทดลองทำแล้วก็ยังไม่ได้ เมื่อเราเพิ่มขึ้นมาอีกแถวหนึง ใน IE ก็มีปัญหา แก้แล้วก็ยังไม่ดีมากนัก ปัญหานี้ยังสู้ตารางไม่ได้อยู่คับ ผมคิดว่าถ้าทำCSS ได้เกือบเท่าตารางเมื่อไหร่ จะมีคนทำ Webstandard มากขึ้น ยังไงก็ช่วยกันพัฒนาน่ะคับ

  5. admin said,

    กันยายน 13, 2007 @ 1:17 pm

    อันนี้ใช้สำหรับ layout ซ้ายกลางขวาอะครับ อย่าไปใช้แทนตารางเลยครับ มันคนละอย่างกัน ส่วนของตารางใช้ table ดีอยู่แล้วครับ ถ้าจะทำ css div ให้เป็นตาราง ก็คงมีกระอักเลือดกันมั่งละครับ :(|)

  6. RookieDZ said,

    กันยายน 26, 2007 @ 7:44 pm

    ครับใช่แล้วล่ะคับ ผมว่าเราไม่จำเป็นต้องสร้าง Div ในรูปแบบตารางเลยน่ะคับ

  7. Petch said,

    เมษายน 26, 2008 @ 8:31 pm

    อยากถามเกี่ยวกับปัญหาที่เกิดกับ Browser IE ครับ Text ที่อยู่ในแต่ละบล็อกมันล้นออกมา โดยเฉพาะบล๊อกอันล่างสุด ไม่ทราบว่าสาเหตุเกิดจากการใช้ Float หรือการใช้ Div Class ที่ซ้ำซ้อนกันหรือเปล่าครับ ผมลองใช้ Clear-all แล้ว ก็หายไปบ้างนิดหน่อย ทำอย่างไรจึงจะแก้ปัญหานี้ได้ครับ หรือให้เปลี่ยนไปใช้ Ul li dl dd เป็นโครงสร้างของ Block แทนครับ

  8. divland's people said,

    เมษายน 26, 2008 @ 10:55 pm

    ผมว่า พิมพ์แล้วไม่เคาะ space บ่อยๆหรือป่าวครับ มันถึงยาวจนล้นออกมา ลองใส่ css ตัวนี้ที่กล่องดูเผื่อช่วยได้ครับ white-space:nowrap;

RSS feed for comments on this post · TrackBack URI

ให้ความเห็น

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

email

จัดส่งถึงที่ โดย

ลิ้งค์สำหรับ rss reader


ลงโฆษณา ติดต่อ cssmaster@divland.com
ASTORE Astoreblog.com
LOAD uploadtoday.com