Unlimited Plugins, WordPress themes, videos & courses! Unlimited asset downloads! From $16.50/m
Advertisement
  1. Code
  2. Web Development
Code

CSS Selector 30 ตัวที่ควรจำ

by
Difficulty:IntermediateLength:LongLanguages:
This post is part of a series called CSS3 Mastery.
10 CSS3 Properties you Need to be Familiar With
Getting to Work with CSS3 Power Tools

Thai (ภาษาไทย) translation by Porrapat Petchdamrongskul (you can also view the original English article)

คุณคิดว่าคุณได้เรียนพื้นฐานเรื่อง id, class และ descendant selector แล้วคิดว่าพอ? ถ้าคำตอบนั้นคือใช่ นั่นแปลว่าคุณพลาดในเรื่องความยืดหยุ่นจำนวนมากที่คุณจะได้ใช้แล้ว ขณะที่ selector จำนวนมากในบทความนี้อยู่ใน CSS3 specification และใช้ได้เฉพาะบราวเซอร์รุ่นใหม่ล่าสุดเท่านั้น บางทีคุณอาจจะต้องบอกกับตัวคุณเองทีหลังว่า คุณน่าจะจำมันได้ตั้งนานแล้ว

1. *

เริ่มง่ายๆ ตัวแรกเลยสำหรับมือใหม่ ก่อนที่คุณจะเจอ selector ขั้นสูงกว่านี้ต่อ

สัญลักษณ์ดอกจันทร์ (*) นั้น select ทุกๆ element บน page นักพัฒนาจำนวนมากจะใช้เทคนิคนี้ในการ Set ค่า margin และ padding ให้เท่ากับ 0 ขณะที่มันโอเคเลยที่จะใช้ในการเขียนทดสอบ แต่ผมก็ขอแนะนำว่าอย่าได้ใช้มันใน production code จะดีที่สุด เพราะมันทำให้ browser นั้น ทำงานหนัก ในการประมวลผลโดยไม่จำเป็น

* สามารถใช้ร่วมกับ child selector ได้ ตัวอย่างเช่น

ตัวอย่างนี้จะ select ทุกๆ element ที่เป็นลูกของ #container div โปรดฟังอีกครั้งหนึ่ง พยายามอย่าใช้เทคนิคนี้ถ้าไม่จำเป็น

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE6+
  • Firefox
  • Chrome
  • Safari
  • Opera

2. #X

ใส่เครื่องหมายสี่เหลี่ยม (#) ไว้ด้านหน้านั้นแปลว่าให้เรา select โดยใช้ id โดยทั่วไปมันง่ายที่จะใช้ แต่อย่างไรก็ตามเราควรระวังในการใช้ id selector

ถามตัวคุณเองว่า แน่ใจหรือว่าต้องการใส่ id เข้ากับ element นี้เพื่อทำการเลือกมันโดยเฉพาะเจาะจง

id selector นั้นไม่ยืดหยุ่น มันไม่อนุญาตให้ใช้ซ้ำ ถ้าเป็นไปได้ เริ่มแรกให้พยายามใช้ tag name ของ HTML5 ซึ่งเป็น element แบบใหม่ หรือใช้ pseudo-class แทน (หมายเหตุจากผู้แปล Tag Name ก็เช่น section,article เป็นต้น)

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE6+
  • Firefox
  • Chrome
  • Safari
  • Opera

3. .X

นี่คือ class selector ความต่างระหว่าง id และ class นั้นคือคุณสามารถระบุ element ได้หลายตัว โดยการใช้ class เมื่อคุณต้องการใส่ style เข้ากับกลุ่มของ element แต่ใช้ id เพื่อระบุ element ที่เจาะจงไปเลย

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE6+
  • Firefox
  • Chrome
  • Safari
  • Safari

4. X Y

ถัดไปคือ selector ที่ต้องช่วยใส่ใจกันให้มากๆ มันชื่อ descendant selector ใช้เมื่อคุณต้องการระบุ selector ของคุณให้เฉพาะเจาะจงยิ่งขึ้น ยกตัวอย่าง อะไรจะเกิดขึ้นถ้า แทนที่คุณจะระบุทุกๆ tag a (anchor tags) ทั้งหมด แต่จริงๆ แล้วคุณต้องการระบุ tag a เฉพาะที่อยู่ใต้ unordered list เท่านั้น แน่นอนคุณสามารถระบุได้โดยใช้ descendant selector

Pro-tip - ถ้า selector ที่คุณเขียนเป็นแบบนี้เช่น X Y Z A B.error คุณว่าคุณทำไรผิดไปรึเปล่า ถามตัวคุณเองก่อนเสมอว่า จำเป็นรึที่จะต้องระบุ ละเอียด ขนาดนั้น? 

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE6+
  • Firefox
  • Chrome
  • Safari
  • Opera

5. X

แล้วถ้าคุณต้องการระบุทุกๆ element บน page โดยใช้ type แทนที่จะใช้ id หรือชื่อ class หล่ะ ง่ายๆ เลยใช้ type selector ถ้าคุณต้องการระบุ unordered list ทุกตัว ใช้ ul {}

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE6+
  • Firefox
  • Chrome
  • Safari
  • Opera

6. X:visited and X:link

เราใช้ :link pseudo-class เพื่อที่จะระบุทุกๆ tag a ที่คุณยังไม่ได้ไปคลิก

นอกจากนี้ เราใช้ :visited pseudo class ที่คุณก็เดาได้ว่ามันจะไป style กับ tag a บน page ที่คุณ เคยไปคลิก หรือ เคยไปเยี่ยมชม แล้วนั่นเอง

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE7+
  • Firefox
  • Chrome
  • Safari
  • Opera

7. X + Y

นี่เรียกว่า adjacent selector มันจะระบุเฉพาะ element ที่อยู่ชิดถัดจาก element ต้นทาง (อยู่ชิดติดกันจริงๆ) ในกรณีนี้ เฉพาะ paragraph แรกที่อยู่ชิดต่อหลังจาก ul แต่ละตัว จะแสดงตัวอักษรสีแดง

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE7+
  • Firefox
  • Chrome
  • Safari
  • Opera

8. X > Y

ความแตกต่างระหว่าง X Y กับ X > Y คือ ตัวหลังจะเลือกเฉพาะ element ลูกที่อยู่โดยตรงลงไปหนึ่งชั้นเท่านั้น ตัวอย่าง ลองดู markup ต่อไปนี้

selector #container > ul จะเลือกเฉพาะ ul ที่เป็นลูกโดยตรงของ div ที่มี id ชื่อ container เท่านั้น มันจะไม่ระบุ ul ที่อยู่ภายใน li ตัวแรก

ด้วยเหตุนี้ จะก่อให้ส่งผลให้โค้ดทำงานได้มีประสิทธิภาพมากขึ้นในการใช้ child combinator อันนี้ ในความเป็นจริง มันเหมาะอย่างยิ่งในกรณีที่คุณทำงานกับ CSS engine ที่อยู่ในภาษา JavaScript

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE7+
  • Firefox
  • Chrome
  • Safari
  • Opera

9. X ~ Y

นี่คือ sibling combinator ที่ดูคล้ายกับ X + Y อย่างไรก็ตามมันจะยืดหยุ่นกว่า ขณะที่ adjacent selector (ul + p) จะเลือกเฉพาะ element ที่อยู่ต่อและติดกับ selector ก่อนหน้าโดยทันที แต่อันนี้จะทำงานได้กว้างกว่าที่ จากตัวอย่างมันจะเลือก p element ทุกตัวเลยที่อยู่ต่อจาก ul 

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE7+
  • Firefox
  • Chrome
  • Safari
  • Safari

10. X[title]

อันนี้เรียกว่า attribute selector ในตัวอย่างด้านบน มันจะเลือกเฉพาะ tag a ที่มีแอตทริบิวต์ title เท่านั้น Tag a อื่นๆ จะไม่ได้รับผลกระทบ อธิบายง่ายๆ ก็แค่คุณต้องการเลือกให้เฉพาะเจาะจงมากขึ้น เท่านั้นแหละ...

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE7+
  • Firefox
  • Chrome
  • Safari
  • Opera

11. X[href="foo"]

โค้ดด้านบนนั้นจะ style ทุกๆ tag a ที่ link ไปที่ https://net.tutsplus.com มันจะทำให้ลิ้งค์นั้นมีสีเขียวเข้ม tag a อื่นๆ นั้นจะไม่ได้รับผลกระทบ

สังเกตว่าเราจะนำค่าใส่ไว้ในเครื่องหมาย " " จำไว้ว่าต้องทำแบบนี้ด้วยถ้าคุณใช้ CSS selector ที่มาจาก engine ของภาษา JavaScript ถ้าเป็นไปได้ ให้ใช้ CSS3 selector ไปเลยโดยตรงแทนที่จะใช้ unofficial method เหล่านี้

มันทำงานได้ดี แม้ว่า ค่อนข้างตรงไปหน่อย ถ้าลิ้งที่โดยตรงไปยัง Nettuts+ แต่เขียน path ในรูปแบบ nettuts.com แทนที่จะเป็น url แบบเต็มหล่ะ ถ้าเป็นแบบนั้น เราสามารถใช้ syntax ของ regular expression แทนได้

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE7+
  • Firefox
  • Chrome
  • Safari
  • Opera

12. X[href*="nettuts"]

นั่นแหละ ที่เราต้องการ เครื่องหมายดอกจันทร์ระบุว่า ค่านั้นจะ ปรากฏที่ไหน ก็ได้ใน attribute โดยวิธีนี้เอง ทำให้การระบุครอบคลุมถึง nettuts.com net.tutsplus.com และก็ tutsplus.com

จำไว้ว่าการใช้แบบนี้ค่อนข้างกว้าง ถ้า tag a นั้น link ไป site ที่ไม่ใช่ Envato ถึงแม้มี tuts นั้นอยู่ใน url หล่ะ มันก็โดนเลือกด้วย ฉะนั้นเมื่อคุณต้องการระบุให้ชัดเจนเข้าไปอีก ก็ให้ใช้ ^ กับ $ เพื่อระบุถึงจุดเริ่มต้นและจุดสิ้นสุดของ string ตามลำดับ

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE7+
  • Firefox
  • Chrome
  • Safari
  • Opera

13. X[href^="http"]

เคยแปลกใจไหมว่าบางเว็บไซต์นั้นสามารถแสดง icon เล็กๆ ถัดจาก link ที่ออกไปยังเว็บไซต์ภายนอก ผมมั่นใจว่าคุณต้องเคยเห็นมาก่อน มันเป็นตัวแจ้งเตือนที่ดีที่บอกว่า คุณจะออกไปเว็บอื่นแล้วนะ

สัญลักษณ์ ^ อันนี้ มันถูกใช้โดยทั่วไปใน regular expression เพื่อบ่งบอกจุดเริ่มต้นของ string ถ้าเราต้องการระบุ tag a ทั้งหมดที่มี href  ที่เริ่มต้นด้วย http เราควรใช้ selector ประมาณโค้ดด้านบน

สังเกตว่าเราไม่หา https:// ตรงๆ มันไม่จำเป็น เพราะมันยังมี url แบบอื่นด้วย ตัวอย่างเช่นการขึ้นต้นด้วย https:// เป็นต้น

และก็ ถ้าคุณต้องการ style เจ้า tag a ทั้งหมดที่ link ไปยังรูปภาพ ในกรณีนี้ให้ใช้การค้นหาแบบ จุดสิ้นสุด ของ string แทน (ซึ่งจะกล่าวถัดไป)

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE7+
  • Firefox
  • Chrome
  • Safari
  • Opera

14. X[href$=".jpg"]

อีกครั้ง เราใช้สัญลักษณ์จาก regular expression $ เพื่อบ่งบอกถึงจุดสิ้นสุดของ string ในกรณีนี้ เรากำลังค้นหาทุกๆ tag a ที่ link ไปยัง image หรืออย่างน้อย url ใดๆ ที่ลงท้ายด้วย .jpg จำไว้ว่ากรณีนี้จะใช้กับ gif และ png ไม่ได้

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE7+
  • Firefox
  • Chrome
  • Safari
  • Opera

15. X[data-*="foo"]

อ้างอิงกลับไปยังข้อที่สิบสี่ด้านบน แล้วถ้าเราต้องการเอาทุกๆ image type หล่ะ (png, jpeg, jpg, gif) ถ้าอย่างนั้น เราต้องสร้าง multiple selector แบบนี้ 

แต่นั่นมันดูแสนเหนื่อยใจและไร้ประสิทธิภาพ ความเป็นไปได้อื่นๆ เช่นการใช้ custom attribute แล้วถ้าเราเพิ่ม data-filetype attribute ของเราเองไปที่ tag a แต่ละอันที่ link ไปยังรูปภาพหล่ะ

จากนั้น เมื่อเข้าที่เข้าทางแล้ว เราสามารถใช้ attribute selector ทั่วไปในการระบุ tag a เหล่านั้น

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE7+
  • Firefox
  • Chrome
  • Safari
  • Opera

16. X[foo~="bar"]

มันเป็น selector แบบพิเศษแบบหนึ่งที่จะทำให้เพื่อนคุณประทับใจ มีคนไม่กี่คนที่รู้ trick นี้ สัญลักษณ์ตัวหนอนหรือ tilda symbol (~) ช่วยให้เราระบุ list ของ attribute ที่ซึ่งคั่นด้วยเครื่องหมายเว้นวรรค

ไปที่ custom attribute ข้อ 15 ด้านบน เราสามารถสร้าง data-info attribute ที่ซึ่งครอบคลุมรายการที่คั่นด้วยการเว้นวรรคใดๆ ได้ ในกรณีนี้ เราจะสามารถระบุ external link และ link ไปยังรูปภาพต่างๆ ได้ -- นี่คือตัวอย่าง

ด้วยการใส่ค่าไปใน markup เราสามารถระุบ tag ใดๆ ที่มีค่าเหล่านั้น ด้วยการใช้เทคนิคจาก attribute selector อันนี้

ง่ายใช่ไหมหล่ะ?

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE7+
  • Firefox
  • Chrome
  • Safari
  • Opera

17. X:checked

pseudo class นี้เพียงแค่ระบุ element ของ user interface ที่ได้รับการเลือก (checked) เช่น radio button หรือ checkbox มันก็น่าจะเข้าใจง่ายๆ ตามนั้น...

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE9+
  • Firefox
  • Chrome
  • Safari
  • Opera

18. X:after

pseudo class before และ after นั้นเจอเต็มๆ ทุกๆ วัน เหมือนว่าผู้คนสามารถค้นหาวิธีที่สร้างสรรค์ใหม่ๆ เพื่อที่จะใช้มันให้เกิดประสิทธิภาพมากที่สุด พวกมันทำงานง่ายๆ แค่การสร้าง content รอบๆ element ที่ถูกเลือก

หลายคนเห็นพวกมันครั้งแรกเมื่อต้องเจอกับเทคนิคที่เรียกว่า clear-fix hack

clear-fix hack นี้ใช้ pseudo class :after ในการสร้างอักขระเว้นวรรค หรือ space หลังจาก element จากนั้นทำการ clear มัน มันช่างเป็นเทคนิคที่ยอดเยี่ยมที่คุณต้องมีและเก็บใส่หัวไว้เลย โดยเฉพาะในกรณีที่ไม่สามารถใช้คำสั่ง overflow: hidden; ได้

สำหรับการใช้งานแบบสร้างสรรค์อื่นๆ โปรดดูที่ เทคนิคสั้นๆ ในการสร้างแสงเงา (quick tip on creating shadows)

อ้างอิง CSS3 Selector specification คุณควรใช้เทคนิคนี้บน pseudo element ด้วย syntax ที่ใช้โคล่อน 2 ตัวติดกัน ::  อย่างไรก็ตาม เพื่อความเข้ากันได้ ควรใช้โคล่อนอันเดียวจะดีกว่า ในความเป็นจริง มันดีกว่าที่จะใช้เวอร์ชั่น colon อันเดียวในโปรเจคของคุณ

บราวเซอร์ที่รองรับ

  • IE8+
  • Firefox
  • Chrome
  • Safari
  • Opera

19. X:hover

โอ้ และก็มาถึง คุณก็รู้อันนี้ มันเป็น official term ที่เรียกว่า user action pseudo class ชื่อนั้นทำให้สับสน แค่ต้องการใส่ style เฉพาะเจาะจงไปบน element ทุกชนิดเมื่อคุณเอาเม้าส์ไปวางหรือ hover  นี่แหละมันใช่เลย

โปรดจำไว้ว่า Internet Explorer เวอร์ชันเก่าๆ ไม่ตอบสนองกับ :hover pseudo class ที่ใส่กับ element อื่นๆ ที่ไม่ใช่ tag a (anchor tag)

คุณมักจะได้ใช้ selector ตัวนี้บ่อยๆ เช่นการทำ border-bottom เมื่อคุณเอาเม้าส์ hover มัน

Pro-tip - border-bottom: 1px solid black; นั้นดูดีกว่า text-decoration: underline;

บราวเซอร์ที่รองรับ

  • IE6+ (ใน IE6, :hover นั้น ใช้ได้กับ tag a หรือที่เรียกว่า anchor element เท่านั้น)
  • Firefox
  • Chrome
  • Safari
  • Opera

20. X:not(selector)

pseudo class แบบ negation ค่อนข้างใช้ได้ดี ลองคิดว่าผมต้องการเลือก tag div ทั้งหมด ยกเว้นแค่ตัวที่มี id ที่ชื่อ container โค้ดด้านบนสามารถทำได้ดีเลยทีเดียว

หรือ ถ้าผมต้องการเลือกทุกๆ element ยกเว้น tag paragraph เราจะใช้โค้ดนี้จัดการ (ซึ่งแน่นอน ไม่แนะนำให้ใช้)

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE9+
  • Firefox
  • Chrome
  • Safari
  • Opera

21. X::pseudoElement

เราสามารถใช้ pseudo element (ที่แสดงโดยสัญลักษณ์ ::) เพื่อ style บน element เช่นใช้กับบรรทัดแรก หรือ อักษรตัวแรก จำไว้ว่าต้องใส่ที่ block level element เท่านั้นเพื่อที่จะให้มันแสดงผล

pseudo-element นั้นเกิดจากสัญลักษณ์โคล่อนสองตัว ::

ระบุตัวอักษรตัวแรกของ Paragraph

โค้ดด้านบนบอกว่า เราจะไปที่ทุกๆ paragraph บน page จากนั้นระบุแค่ตัวอักษรตัวแรกของ element paragraph เท่านั้น

มันใช้บ่อยเหมือนกับสไตล์ของบทความในหนังสือพิมพ์ที่มักทำให้ตัวอักษรตัวแรกดูใหญ่

ระบุบรรทัดแรกของ Paragraph

คล้ายๆกัน pseudo element ::first-line  นั้นเดาได้เลยว่าจะ style บรรทัดแรกของ element เท่านั้น

เพื่อความเข้ากันได้กับ style sheet ที่มีอยู่แล้ว ผู้ใช้ต้องยอมรับว่า colon 1 อัน ใช้สำหรับ pseudo-element ที่มีอยู่ใน CSS level 1 และ 2 (อันที่ชื่อว่า :first-line, :first-letter, :before และ :after) ความเข้ากันได้อันนี้จะไม่สามารถใช้ได้กับ pseudo-element แบบใหม่ใน specification นี้ - ที่มา

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE6+
  • Firefox
  • Chrome
  • Safari
  • Opera

22. X:nth-child(n)

จำได้ไหมว่าเราไม่มีวิธีที่จะระบุ element ในกลุ่มที่เราเลือกออกมา nth-child นั้นจะเข้ามาแก้ปัญหาให้

สังเกตว่า nth-child นั้นจะรับค่า integer ที่ parameter ไม่ใช่ zero-based เช่น ถ้าคุณต้องการระบุ item อันที่สอง ก็ใช้ li:nth-child(2) ตรงๆ ไปเลย

คุณยังสามารถใช้ตัวแปรเพื่อ select ได้อย่างเช่น เราใช้ li:nth-child(4n) เพื่อ select ทุกๆ list item อันที่ 4

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE9+
  • Firefox 3.5+
  • Chrome
  • Safari

23. X:nth-last-child(n)

แล้วถ้าเรามี list ขนาดใหญ่ที่มี item อยู่เป็นจำนวนมากแหละ สมมุติเราต้องการ item อันที่ 2 จากท้ายที่อยู่ใน ul แทนที่จะใช้ li:nth-child(397) คุณควรใช้ pseudo class nth-last-child แทน 

เทคนิคนี้ใช้ได้เกือบเหมือนกับข้อ 22 ด้านบน อย่างไรก็ตามเทคนิคนี้เริ่มจากข้างหลังแทน

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE9+
  • Firefox 3.5+
  • Chrome
  • Safari
  • Opera

24. X:nth-of-type(n)

จะมีบางครั้งแทนที่คุณจะ select โดยใช้ child แต่คุณจำเป็นต้องใช้ type ในการ select element

จินตนาการว่า mark-up นั้นประกอบไปด้วย unordered list 5 อัน ถ้าคุณต้องการ style เพียงแค่ ul ตัวที่สาม และไม่มี id เฉพาะเกี่ยวข้องด้วย คุณควรใช้ nth-of-type(n) pseudo-class ในโค้ดด้านบน เพียงแค่ ul ตัวที่สามนั้นจะแสดง border รอบๆ มัน

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE9+
  • Firefox 3.5+
  • Chrome
  • Safari

25. X:nth-last-of-type(n)

และใช่ เพื่อให้คู่กัน เราสามารถใช้ nth-last-of-type เพื่อเริ่มด้านหลัง ไปที่ element ที่เราต้องการแทน

บราวเซอร์ที่รองรับ

  • IE9+
  • Firefox 3.5+
  • Chrome
  • Safari
  • Opera

26. X:first-child

pseudo class แบบนี้จะทำให้เราระบุแค่ child ตัวแรกของ element parent บ่อยครั้งคุณจะใช้มันในการเอา border ออกจาก item ตัวแรกและตัวสุดท้าย

ตัวอย่าง ลองคิดว่าถ้าคุณมี list ของแถวจำนวนหนึ่ง แต่ละอันมี style border-top และ border-bottom ด้วยวิธีนี้ แถวแรกกับแถวสุดท้ายจะดูประหลาด

นักออกแบบจำนวนมากใส่ class first และ last เพื่อจัดการมัน นอกจากนี้ คุณสามารถใช้ pseudo class เพื่อมาช่วยคุณแทน

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE7+
  • Firefox
  • Chrome
  • Safari
  • Opera

27. X:last-child

ตรงข้ามกับ first-child โดยที่ last-child จะระบุ item ตัวสุดท้ายของ element parent แทน

ตัวอย่าง

ลองดูตัวอย่างง่ายๆ ที่จะอธิบายความเป็นไปได้ของการใช้ class เหล่านี้ เราจะทำการสร้างและทำการ style list item

Markup

ไม่มีอะไรพิเศษ แค่ list ธรรมดา

CSS

style ที่เขียนนี้จะใส่สี background เอา padding ที่เป็น browser-default บน element ul ออก และใส่ border เข้าไปกับ li แต่ละตัวเพื่อให้ดูมีมิติ

Styled List

เพื่อเพิ่มมิติไปยัง list ของคุณ ให้ใส่ border-bottom ไปที่แต่ละ li นั่นจะทำให้เกิดเฉดสีดำมากกว่าสี background ของ li จากนั้น ใส่ border-top ที่ทำให้เฉดสีดูสว่างขึ้น

ปัญหาเดียวสำหรับภาพด้านบนก็คือ border จะถูกใส่ทุกๆ top และ bottom ของ unordered list ด้วย ซึ่งไม่ใช่ที่เราต้องการ ให้ใช้ pseudo :first-child และ :last-child เพื่อมาแก้ไขมัน

Fixed

นั่นแหละ! แก้ได้แล้ว

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE9+
  • Firefox
  • Chrome
  • Safari
  • Opera

ใช่แล้ว - IE8 support แค่ :first-child เท่านั้นซึ่ง :last-child ไม่รวมอยู่ด้วย คุณสามารถลองดูได้

28. X:only-child

ในความเป็นจริง คุณจะไม่ค่อยพบว่าคุณใช้ pseudo class only-child นี้บ่อยนัก ไม่หรอก ในเมื่อมันมี บางทีคุณอาจต้องใช้มัน

มันช่วยให้คุณระบุ element ที่เป็นลูกตัวเดียวของ parent เท่านั้น (ตามชื่อ only child)  ตัวอย่าง ลองดูโค้ดด้านบน เพียงแค่ paragraph ที่เป็นลูกตัวเดียวของ div นั้นจะมีสีแดง

ลองดู markup ต่อไปนี้ก็ได้

ในกรณีนี้ paragraph ภายใน div ตัวที่สองจะไม่ถูกเลือก จะแสดงผลแค่ใน div ตัวแรกเท่านั้น ตราบใดที่คุณมี child แค่ตัวเดียวใน element นั่นแหละ pseudo class only-child จะได้ทำงาน

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE9+
  • Firefox
  • Chrome
  • Safari
  • Opera

29. X:only-of-type

pseudo class อันนี้สามารถใช้ได้หลากหลาย มันจะระบุ element ที่ไม่มีพี่น้อง (sibling) ภายใน parent ที่ครอบมัน จากตัวอย่าง ลองระบุ ul ทั้งหมดที่มีแค่ list อันเดียว

แรกเลย ถามตัวคุณเองก่อนว่าจะทำได้อย่างไร คุณสามารถใช้ ul li แต่ว่ามันจะเลือก list ทั้งหมด ไม่ต้องเดาละมีคำตอบเดียวเลยคือใช้ only-of-type

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE9+
  • Firefox 3.5+
  • Chrome
  • Safari
  • Opera

30. X:first-of-type

pseudo class first-of-type ทั้งจะช่วยให้เราเลือกพี่น้องแรก (first sibling) ภายใน type ของมัน

เริ่มทดสอบ

เพื่อให้เข้าใจมากขึ้น เราจะมาทดลองกัน Copy mark-up ต่อไปนี้ไปที่ code editor ของคุณ

และก็ อย่าเพิ่งอ่านอะไรถัดไปนะ ลองเดาว่าจะทำอย่างไรจึงจะเลือกเฉพาะ "List item อันที่ 2" ได้ เมื่อคุณพบคำตอบแล้ว (หรือยอมแพ้ 555+) อ่านต่อเลย

เฉลยวิธีที่ 1

มีวิธีการมากมายที่จะแก้ปัญหา เราจะ review แค่บางอัน เริ่มจากการใช้ first-of-type

โค้ดสั้นกระชับนี้บอกว่า "ค้นหา unordered list ตัวแรกใน page จากนั้นหาเฉพาะที่มีลูกที่เป็น list ตามมา จากนั้น เอาแค่ตัวที่สองที่อยู่ในนั้น

เฉลยวิธีที่ 2

ตัวเลือกอื่นคือใช้ adjacent selector

ในเหตุการณ์นี้ เราจะหา ul ที่ตามติดมาด้วย p tag และค้นหา element ที่เป็นตัวสุดท้าย

เฉลยวิธีที่ 3

เราสามารถรู้สึกได้ทั้งรำคาญหรือสนุก? ตราบที่เราต้องการ selector เหล่านี้

ครั้งนี้ เราเลือก ul ตัวแรกบน page จากนั้นค้นหา list item ตัวแรก แต่ว่าเริ่มจากท้ายนะ! :)

แสดงตัวอย่าง

บราวเซอร์ที่รองรับ

  • IE9+
  • Firefox 3.5+
  • Chrome
  • Safari
  • Opera

สุดท้าย

ถ้าคุณกังวลเกี่ยวกับ browser รุ่นเก่าๆ เช่น Internet Explorer 6 คุณก็ต้องระวังในการใช้ selector ใหม่ๆ เหล่านี้ด้วย แต่อย่างว่า ถ้ามันทำให้คุณถูกขวางกั้นจากการเรียนรู้สิ่งเหล่านี้ หรือเหมือนคุณไม่ค่อยสบายใจ ไงก็ลองเช็ค browser-compatibility จากที่นี่ดู หรือว่าคุณอาจใช้ Dean Edward's excellent IE9.js script เพิ่มเข้าไปในโค้ดของคุณเพื่อทำให้ browser รุ่นเก่าๆ support เจ้า selector เหล่านี้ได้

จากนั้น เมื่อคุณทำงานกับไลบารี่ Javascript เช่น jQuery ที่แสนโด่งดัง จำไว้เสมอ ถ้าเป็นไปได้ให้พยายามใช้ native CSS3 selector เพียวๆก่อน แทนที่จะใช้จากตัว library  มันจะทำให้ code ของคุณทำงานได้ไวขึ้น เพราะ engine ของ selector สามารถถูก parse ได้โดยตรง (native parsing)

เอาหล่ะ! ขอบคุณที่อ่านและติดตาม ผมหวังว่าคุณจะได้ trick ดีๆ ไปบ้าง ไม่มากก็น้อยหล่ะ!

Advertisement
Advertisement
Advertisement
Advertisement
Looking for something to help kick start your next project?
Envato Market has a range of items for sale to help get you started.