Advanced tutorial: Pseudo-elements ::before and ::after
What are pseudo-elements
Pseudo-element
Example
Description
::after
p::after
div::after
Placed after the content of specified element
::backdrop
dialog::backdrop
Applies styles to the background behind a dialog box or popover
::before
p::before
div::before
Placed before the content of specified element
::file-selector-button
::file-selector-button
Selects any button for file uploads (<input type="file">)
::first-letter
p::first-letter
Targets the first letter in each <p> element
::first-line
p::first-line
Targets the first line in each <p> element
::grammar-error
p::grammar-error
Styles text marked as grammatically incorrect by the browser
::highlight()
::highlight(custom-name)
Selects a custom text highlight applied to an element
::marker
li::marker
Styles the markers (bullets or numbers) of list items
::placeholder
input::placeholder
textarea::placeholder
Styles placeholder text in <input> or <textarea> fields
::selection
div::selection
Applies styles to text selected by the user
::spelling-error
p::spelling-error
Styles text marked as misspelled by the browser
::view-transition
::view-transition
Represents the root element for the view transitions overlay, containing all view transitions on the page
::view-transition-group
::view-transition-group
Represents a single snapshot group for a view transition
::view-transition-image-pair
::view-transition-image-pair
Acts as a container for the "old" and "new" view states during a view transition.
::view-transition-new
::view-transition-new
Represents the "new" view state after a view transition completes.
::view-transition-old
::view-transition-old
Represents the "old" view state before a view transition starts.
How to use ::before and ::after
Adding custom list decoration
data:image/s3,"s3://crabby-images/c0a32/c0a32498a18bca63916fcf3f1ab06461edc6e2a0" alt=""
Select the text you want to list, and switch it to a pointed list.
data:image/s3,"s3://crabby-images/e2969/e296925ea20b2896908acc46b2a7e6af36f49681" alt=""
data:image/s3,"s3://crabby-images/d9971/d9971ddacb9fb9634d7cf8eca3588ed4759c9012" alt=""
data:image/s3,"s3://crabby-images/3cf9c/3cf9cae65d34e1c43fd6a3eab942289b0eb1f0e4" alt=""
data:image/s3,"s3://crabby-images/badd7/badd7e70a23e69aa805095a1310fef256517d0bf" alt=""
Get back to the before selector and in the Pseudoelement content write down the proper line:
url:("/upload/domain/12345/images/icon-name.svg").
data:image/s3,"s3://crabby-images/75033/750337620b18678d34fd9840d308b744c714911c" alt=""
data:image/s3,"s3://crabby-images/a5c12/a5c1297dd21b0c9dd0f3c8158f4ce7ff4c0b88a8" alt=""
Make animated underline to a navigation link
Another interesting usage is to create an animated underline for a link in your menu navigation. Normal text underline is very simplistic and aside from changing a color it doesn’t provide any more styling flexibility. But we can work around it.
Click on the navigation link and go to widget styles.
data:image/s3,"s3://crabby-images/28a44/28a448561122dee97b2bc18760f309e0a72be799" alt=""
data:image/s3,"s3://crabby-images/a1556/a1556d16f3687981ffd9769ff0f0d4319d7324a1" alt=""
In the size editor set the width to 0% and the height for 2px.
data:image/s3,"s3://crabby-images/3868b/3868b387b017c03ca1ce08450b0f1d51167388c4" alt=""
data:image/s3,"s3://crabby-images/7223b/7223b4a7eab59e9a0a4c441c91c4e6d5240c3dba" alt=""
data:image/s3,"s3://crabby-images/ea3c1/ea3c16ca08299b3c7faa7953da81da16776d55e6" alt=""
Now that we have our base set-up, let’s adjust the hover state. Inside the selector, using the same selector we just styled, but we need to add a hover state to the link (not to the pseudo-element), so it would look like this:
“.nav-top-item:hover::before” (or “.navigation-items .nav-top-item:hover::before”).
data:image/s3,"s3://crabby-images/ec971/ec9719f36aed4f8e498d483695050e5e7bdb68f7" alt=""
data:image/s3,"s3://crabby-images/367e8/367e814fd599bf229a1a411d97e14030dfc60407" alt=""
data:image/s3,"s3://crabby-images/742de/742def5f34306b424f6782734d914539191c6094" alt=""