Table of Contents
Basic Grammar
Second Advanced Tips
Three special effects
Home Web Front-end HTML Tutorial What you don't know about CSS ::before and ::after pseudo-elements_html/css_WEB-ITnose

What you don't know about CSS ::before and ::after pseudo-elements_html/css_WEB-ITnose

Jun 24, 2016 pm 12:00 PM
css element usage

This article is equivalently inspired by an insight into programming life.

CSS has two pseudo-classes that are not commonly used: before and :after. They are occasionally used by people to add custom formats, but their functions are not limited to that. A few days ago, I discovered Creative Link Effects, a very interesting page that introduces creative link effects. The amazing effects in it use a lot of features. In addition to the transform attribute for deformation, these two pseudo-elements will be introduced next.

Creative Button Styles

Basic Grammar

Before understanding advanced applications, let’s first understand the grammar rules . When you usually only need to use these two pseudo-elements to add some custom characters, you only need to use the single colon writing method used by the pseudo-class to ensure browser compatibility:

Html Code

  1. p:before {}

However, in CSS3, in order to distinguish pseudo elements and pseudo classes, they are pseudo The element uses double colons, so if attributes such as display or width are used to separate the display from the original element, it is recommended to double-write according to the standard. Browsers that are too old may have support issues, but most pseudo elements are used with CSS3, so there is no need to be backward compatible:

Html code

  1. img::after {}

The unique attribute content under these two pseudo-classes is used to add logical headers to elements in CSS rendering. Add content at the beginning or end. Note that these additions will not change the document content, will not appear in the DOM, cannot be copied, and will only be added in the CSS rendering layer. The following values ​​are useful:

  • [String] - Enclosing a string in quotes will add the string to the element content. Example:

    Html code

    1. a:after { content: "?"; }
  • attr() ? Calling the attributes of the current element can conveniently display the Alt prompt text of the image or the Href address of the link. Example:

    Html code

    1. a:after { content:"(" attr(href) ")"; }
  • url() / uri() ? Used to reference media files. Example:

    Html code

    1. h1::before { content: url(logo.png); }
  • counter() ? By calling the counter, you can implement the serial number function without using list elements. For details, please see the usage of counter-increment and counter-reset attributes. Example:

    Html code

    1. h2:before { counter-increment: chapter; content: "Chapter " counter(chapter) ". " }
  • Second Advanced Tips

    Clearing floats is a problem that is often encountered. The solution for many people is to add an empty The div applies clear:both; attribute. Now, instead of adding meaningless elements, you only need the following style to automatically clear floats at the end of the element:

    Html code

    1. .clear -fix { *overflow: hidden; *zoom: 1; }
    2. .clear-fix:after { display: table; content: ""; width: 0; clear: both; }

    Many people like to add huge quotation marks as the background to the blockquote quotation paragraph. In this case, we can use :before to replace the background, which can leave space for the background and also You can use text directly instead of pictures:

    Html code

    1. blockquote::before {
    2. content: open-quote;
    3. position: absolute;
    4. z-index: -1;
    5. color: #DDD;
    6. font-size: 120px;
    7. font-family: serif;
    8. font-weight: bolder;
    9. }

    Three special effects

    In addition to simply adding characters, with the powerful positioning and special effects features of CSS, you can completely add additional effects to simple elements Attach the effect of up to two containers. One thing to note is that if the content is not required to only cooperate with the style attribute to create an effect, the content attribute cannot be empty, that is, content:"" . Otherwise, other style attributes will not take effect.

    Hovering square brackets appear

    Move the mouse over the link, and square brackets appear:

    Html code

    1. a {
    2. position: relative;
    3. display: inline-block;
    4. outline: none;
    5. text-decoration : none;
    6. color: #000;
    7. font-size: 32px;
    8. padding: 5px 10px;
    9. a:hover::before, a:hover::after { position: absolute; }
    10. a:hover::before { content: "5B"; left: -20px; }
    11. a:hover::after { content: "5D"; right: -20px; }
    Similarly, we only need to match the display : block and position: absolute, you can treat them as two containers and combine them into a special effect of floating double borders:

    Html code

    a {

    position: relative;
    1. display: inline-block;
    2. outline: none;
    3. text-decoration: none;
    4. color: #000;
    5. font-size: 32px;
    6. padding: 0 10px;
    7. }
    8. /* Large frame */
    9. a:hover::before, a:hover::after {
    10. content: "";
    11. display: block;
    12. position: absolute;
    13. top: -15%%;
    14. left: -14%%;
    15. width: 120%;
    16. height: 120%;
    17. border-style: solid;
    18. border-width: 4px;
    19. border-color: #DDD; 🎜>
    20. /* small box */
    21. a:hover::after {
    22. top: 0%;
    23. left: 0 %;
    24. width: 100%;
    25. height: 100%;
    26. border-width: 2px; 🎜>
    27. This article is equivalently inspired by an insight into programming life. Using the :before and :after pseudo-classes to combine more powerful features of CSS3, you can also complete many interesting special effects and Hacks. This is just a starting point. What magical uses can you come up with?

    Statement of this Website
    The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

    Hot AI Tools

    Undresser.AI Undress

    Undresser.AI Undress

    AI-powered app for creating realistic nude photos

    AI Clothes Remover

    AI Clothes Remover

    Online AI tool for removing clothes from photos.

    Undress AI Tool

    Undress AI Tool

    Undress images for free

    Clothoff.io

    Clothoff.io

    AI clothes remover

    AI Hentai Generator

    AI Hentai Generator

    Generate AI Hentai for free.

    Hot Article

    R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
    2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
    Hello Kitty Island Adventure: How To Get Giant Seeds
    1 months ago By 尊渡假赌尊渡假赌尊渡假赌
    Two Point Museum: All Exhibits And Where To Find Them
    1 months ago By 尊渡假赌尊渡假赌尊渡假赌

    Hot Tools

    Notepad++7.3.1

    Notepad++7.3.1

    Easy-to-use and free code editor

    SublimeText3 Chinese version

    SublimeText3 Chinese version

    Chinese version, very easy to use

    Zend Studio 13.0.1

    Zend Studio 13.0.1

    Powerful PHP integrated development environment

    Dreamweaver CS6

    Dreamweaver CS6

    Visual web development tools

    SublimeText3 Mac version

    SublimeText3 Mac version

    God-level code editing software (SublimeText3)

    How to set unknown attributes in vscode vscode method to set unknown attributes How to set unknown attributes in vscode vscode method to set unknown attributes May 09, 2024 pm 02:43 PM

    1. First, open the settings icon in the lower left corner and click the settings option. 2. Then, find the CSS column in the jumped window. 3. Finally, change the drop-down option in the unknownproperties menu to the error button.

    Graphical steps for setting the default properties of CSS in Visual Studio 2019 Graphical steps for setting the default properties of CSS in Visual Studio 2019 May 09, 2024 pm 02:01 PM

    1. Open Visual Studio 2019, find its option settings, and click CSS. 2. Here you can see the technical settings of the following attributes. 3. Now you can set text and fill borders here. 4. At this time, you can also set the floating positioning here. 5. At this moment, you can also set the border and background here to complete the operation. 6. Finally, click the OK button here to set the CSS default properties.

    How to isolate styles in components in vue How to isolate styles in components in vue May 09, 2024 pm 03:57 PM

    Style isolation in Vue components can be achieved in four ways: Use scoped styles to create isolated scopes. Use CSS Modules to generate CSS files with unique class names. Organize class names using BEM conventions to maintain modularity and reusability. In rare cases, it is possible to inject styles directly into the component, but this is not recommended.

    The difference between v-show and v-if in vue The difference between v-show and v-if in vue May 09, 2024 pm 01:48 PM

    The main difference between v-show and v-if in Vue is: v-show: controls the display of elements by changing the display style attribute. It is lightweight and performance-friendly for elements that frequently switch to display/hide; but it will retain the space occupied by the elements. , may cause flickering. v-if: Insert or delete elements through conditions, affecting the layout flow and avoiding flickering; however, the cost of destroying and re-creating elements is high, and it is not suitable for frequently switching displayed/hidden elements.

    How to register for Bitstamp exchange pro? Is it safe? Is it formal? How to register for Bitstamp exchange pro? Is it safe? Is it formal? Aug 13, 2024 pm 06:36 PM

    How to register BitstampPro? Visit the BitstampPro website. Fill in your personal information and email address. Create a password and accept the terms. Verify email address. Is BitstampPro safe? Authentication required. Enforce the use of two-factor authentication. Most assets are stored in cold storage. Use HTTPS to encrypt communication. Conduct regular security audits. Is BitstampPro legitimate? Registered in Luxembourg. Regulated by the Luxembourg Financial Supervisory Committee. Comply with anti-money laundering and know-your-customer regulations.

    How to implement the custom table function of clicking to add data in dcat admin? How to implement the custom table function of clicking to add data in dcat admin? Apr 01, 2025 am 07:09 AM

    How to implement the table function of custom click to add data in dcatadmin (laravel-admin) When using dcat...

    The latest ranking list of virtual currency trading platform APP (inventory of top 10 virtual currency trading platforms) The latest ranking list of virtual currency trading platform APP (inventory of top 10 virtual currency trading platforms) Mar 04, 2025 pm 03:51 PM

    This article lists the top ten leading cryptocurrency exchanges in the world, including OKX, Binance, Gate.io, Huobi, Kraken, Coinbase, KuCoin, Crypto.com, Bitfinex and Bitstamp. With their strong technical strength, rich product lines, strict compliance operations and innovative ecological construction, these exchanges have taken the lead in the global cryptocurrency market. The article will introduce their special functions, technical architecture, security measures, compliance qualifications and ecosystem construction respectively, providing reference for investors to choose a suitable trading platform.

    What is the format of the source file? What is the format of the source file? May 09, 2024 pm 10:51 PM

    Source files are uncompiled files containing original code or data, and their formats vary between programming languages ​​and applications. Common formats include text files (.txt, .csv), programming languages ​​(such as .py, .java), markup languages ​​(such as .html, .css), image files (such as .png, .jpg), video files (such as .mp4, .avi), and other formats such as JSON (.json), PDF (.pdf), Word document (.doc), etc.

    See all articles