Web Technology Web Design Web Programming PHP Wordpress
การที่เราจะเขียนเว็บไซต์ที่ใช้ style sheet โดยเฉพาะแบบ tablelessให้ cross browser
มาสักเว็บนึง เป็นเรื่องที่ยากลำบาก เพราะ web brower รุ่นเก่า มาตรฐานการ render จะต่าง
จาก web browser รุ่นใหม่ แม้กระทั่งยี่ห้อเดียวกัน แต่ต่างรุ่น ก็แสดงผลต่างกัน เช่น IE6 กับ
IE7 ที่แสดงผลบางอย่าง ไม่เหมือนกัน ดังนั้น เพื่อให้บรรลุวัตถุประสงค์(ทำเว็บ cross browser)
เราก็ต้องอาศัย การ hack css เข้าช่วย
CSS hacks คืออะไร?
คือการใช้ bug ของ browser ช่วยในการสร้างเงื่อนไขการทำงานของ style sheet
เพราะบาง browser จะมี bug โดยเฉพาะ IE เช่น คำสั่ง a สามารถใช้กับ IE ได้(เป็น bug ของ IE)
แต่ใช้กับ browser อื่นไม่ได้ เราก็ใช้คำสั่ง a เป็นเงื่อนไขในการสั่งให้ style sheet ทำงาน
ทำให้เราสามารถใช้ 2 คำสั่งที่เหมือนกันได้ แต่ต่างกันตรงที่ ค่าที่ระบุให้คำสั่งนั้นต่างกัน
Important Hack
ตามปกติแล้ว css จะถูกอ่านตามลำดับ ถึงแม้ว่าจะเป็นคำสั่งที่เหมือนกัน แต่คำสั่งสุดท้ายเท่านั้นที่
ถูกใช้งาน ดังตัวอย่างข้างต้นสีตัวอักษรจะเป็นสี #000000 เท่านั้น สี #ff0000 จะไม่มีผล
แต่ถ้าเราใช้คำสั่ง !important
ไม่ว่าคำสั่ง color: #ff0000 !important; จะอยู่ส่วนไหนของเอกสาร(ลำดับการเขียนไม่เป็นผล)
คำสั่งนี้เท่านั้นที่จะถูกทำงาน
แต่คำสั่งนี้ใช้ได้กับ ie6
จากตัวอย่าง ie6 จะใช้คำสั่ง height: 300px; ได้เท่านั้น ส่วน browser อื่นก็ใช้คำสั่ง
height: auto !important; (ลำดับไม่สำคัญเพราะมี !important)
Underscore Hack
เนื่องจาก CSS specification ได้สงวนการขึ้นต้นคำสั่ง(property)ด้วย ขีดล่าง(_) or ขีดกลาง(-)
ไว้ใช้กับ vendor-specific property name จึงทำให้คำสั่งที่ขึ้นต้นด้วย _,- ไม่ถูกอ่านจาก
browser สมัยใหม่ ยกเว้น ie6 เท่านั้น ที่ยังอ่านคำสั่งนี้ได้อยู่
จากตัวอย่าง ie6 จะอ่านทั้งสองคำสั่ง แต่จะสั่งให้ทำงานได้เฉพาะคำสั่งสุดท้าย (วิธีนี้ลำดับการเขียน
มีความสำคัญ) แต่ browser อื่นอ่านคำสั่งแรกเท่านั้น
Backslash Hack
วิธีนี้คือการใส่ \ เข้าไปในชื่อ property ส่งผลให้ browser อื่นละเว้นคำสั่งนี้ แต่ยังคงมีผลกับ ie
(ผมไม่แน่ใจว่ามีผลกับ ie7 หรือป่าว เพราะยังไม่ได้ลอง : P )
จากตัวอย่าง ie ใช้คำสั่ง he\ight: 400px; ส่วน browser อื่น ๆ จะใช้ height: 500px;
note: backslash ไม่ควรใส่นำหน้าตัวอักษร a-f, A-F และ 0-9 เพราะอาจจะถูกตีค่าว่าเป็น
เลขฐาน 16
Star-HTML Hack
ดอกจัน (*) คือ Universal Selector
จากตัวอย่าง ทุก element ในเอกสารจะถูกควบคุมด้วยคำสั่งที่อยู่ในปีกกาของ *
การใช้ Universal Selector จะเห็นผลได้มีอยู่สองกรณีคือ
note: simple selector คือ การเขียน selector ที่ขึ้นต้นด้วย element แล้วตามด้วย
Universal Selector หรือ attribute selectors หรือ ID selectors หรือ pseudo-classes
การใช้ * em จะมีผลกับ
แต่ถ้าหากใช้ universal selector ไม่ได้ตามด้วย simple selector การใช้ universal selector
จะไม่เป็นผล พูดง่าย ๆ ก็คือ ใช้ก็เหมือน ไม่ใช้ ดังตัวอย่างข้างล่างนี้
ทั้งสอง ไม่ต่างกันเลย
มาเข้าเรื่องกัน ถ้าเราใช้ Universal Selector ร่วมกับ html เป็น * html จะเกิดอะไรขึ้น
คำสั่งที่เป็นของ(อยู่ภายในวงเล็บปีกกา) * html จะถูกใช้งานก็ต่อเมื่อ html ถูกสืบทอดมาจาก
element ใด ๆ แต่มันเป็นไปไม่ได้ที่ html จะสืบทอดมาจาก element อื่น เพราะ html เป็น root
ดังนั้น browser ส่วนใหญ่จึงมองข้ามกลุ่มคำสั่งนี้และไม่ประมวลผล แต่ ie6 และต่ำกว่า ie6
จะยังอ่านค่าพวกนี้อยู่ เลยเกิดเป็น bug ของ ie6

ตารางแสดง browser ที่ bug * html
ที่มาตาราง: http://reference.sitepoint.com/css/universalselector
Easy selectors hack
ใช้ได้กับ IE7 เท่านั้น
ใช้ได้กับ IE7 และต่ำกว่า
ใช้ได้กับ IE7 และ browser รุ่นใหม่ อื่น ๆ
ใช้ได้กับ browser รุ่นใหม่ แต่ไม่รวมถึง IE7
สรุป
| ลำดับ | CSS hacks | IE6 | IE7 | Firefox | Safari |
| 1. | !important | / | |||
| 2. | _property หรือ -property | / | |||
| 3. | * html | / | |||
| 4. | *:first-child+html {} | / | |||
| 5. | *:first-child+html {} * html {} | / | / | ||
| 6. | html>body {} | / | / | / | |
| 7. | html>/**/body {} | / | / |
ตารางแสดง bug หรือการ hack ของ browser ที่ประมวลผลบน windows เท่านั้น
เครื่องหมาย “/” ในตารางหมายถึง “ใช้ได้กับ”
References:
callmebird is Bird's weblog. Bird is blogger who spend life for programming and web technology. This weblog provide web technology article for anyone who love web programming and web design.
teehard
July 31st, 2008 at 12:03 am
ขออนุญาตินำบทความไปลงที่blogนะครับ
iNhumBa
August 26th, 2008 at 2:34 pm
มีประโยชน์มากเลย ขอบคุณครับ
trirong
October 29th, 2008 at 2:34 pm
thankyou…
MP3WizarD
December 3rd, 2008 at 11:10 am
แถมให้สำหรับ ie7 … เติม . หน้าชื่อ property จะสามารถทำให้ IE7 และ IE6 สามารถอ่านเฉพาะ property นั้นได้ ยกตัวอย่างเช่น
.test { width:20px; .width:30px; _width:40px; }
browser ทั่วไปจะอ่านความกว้างได้ 20px
IE7 & IE6 จะอ่านได้ 30px (ถ้าลบ _width:40px; ออก)
IE6 จะอ่าน ความกว้างได้ 40px;
งงมั๊ย? ดังนั้น ถ้าเราต้องการเขียนให้ IE7 และ IE6 อ่าน property ตัวนั้น
แต่! มันจะ verify css ไม่ผ่านนะครับ…
tum
January 21st, 2009 at 5:21 pm
validates Css ไม่่่่ผ่าน
ของขวัญ
March 8th, 2009 at 10:58 pm
thankyou…