W03 Learning Activity: CSS Pseudo Selection
Overview
Pseudo-classes and pseudo-elements enhance the abilities and/or content of specific selectors. A pseudo-class is used to define a special state of an element. For example, it can change the color of a button when the user hovers over it with their cursor. A pseudo-element styles specific parts of an element, such as the first letter or the first line of a paragraph.
        You have been using a pseudo-class named :hover which can be used to select a
        button when a user hovers over the button.
      
Pseudo-classes
- Reference: 📑 Pseudo-classes – MDN
- Reference: 📑 :root – MDN
 The:rootCSS pseudo-class can be useful for declaring global CSS variables – MDN.
 What are the advantages of using CSS variables/custom properties?Check Your UnderstandingCSS variables are useful because they improve maintainability by centralizing common values, meaning values can be changed in one convenient place. What does AI say about that advantages of using CSS variables? 
- Open: CodePen ☼ CSS Only Floated Labels – by Nick Salloum
 Can you find all the instances of CSS pseudo-classes being used in this CodePen example?Check Your Understanding- :root
- :focus
- :placeholder-shown
- :not
 
A common design issue with color contrast is not accounting for a browser's default settings, specifically for the link and visited properties of anchor tags. These can be adjusted using pseudo-classes.
Activity Instructions: Pseudo-classes
- Fork (copy) this CodePen ☼ CSS Pseudo-classes Activity to your own CodePen account.
- In your copy on CodePen, add CSS pseudo-class rule(s) for the anchor tags to be navy for both
        activelinks andvisitedlinks.
- Add a CSS pseudo-class rule for the anchor tags to change to purple for the
        hovereffect on links.
- Add CSS pseudo-class rule to provide borders for the div.datatableso that the borders of thediv.colelements do not double up. (see the example screenshot below)
- Make the last row of the data table have a darker gray background color by using the
        :last-childpseudo-class.
- Set up a CSS variable for the border shorthand value in the :rootpseudo-class as1px solid #777;Hints- :root { --bord: _____}then use it with- var(--bord)where needed,
 for example,- border-right: var(--bord);
- Consider using the border-topversus using the CSS border property shortcut to isolate your bordering needs.
- Use the :nth-child()and the:last-childpseudo-classes.
 
 
    Check Your Understanding – Example Solution
CodePen ☼ CSS Pseudo-classes activity solution.
Pseudo-elements
- Reference: 📑 Pseudo-elements – MDN
        Most browsers will actually accept single colons versus double-colons. However, it is good practice to always use double colons ::when selecting pseudo-elements in CSS.
Activity Instructions
- Fork this CodePen ☼ CSS Pseudo Elements to your own CodePen account.
- Add a new CSS rule for the list items in the ordered list that uses a marker pseudo element.
- In this new rule, add 3 declarations to change the ordered list's appearance:
        - make the list item marker a checkmark using content
- make the marker colornavy
- make the font-size2rem
 
- make the list item marker a checkmark using 
Option: Using the Emoji Picker to get a checkmark symbol
- Windows: Press 🪟+.(Windows key + period) [ Windows Keyboard Tips and Tricks ]
- MacOS: ⌘+ctrl+spacebar
Check Your Understanding – Example Solution
CodePen ☼ CSS Pseudo-classes activity solution.