What do one colon and two colons mean in CSS?

One colon is a pseudo-class, and two colons are pseudo-elements.
(Recommended learning: css quick start)
Pseudo classes can assign styles independently of the elements of the document, and can be assigned to any element, logically It is similar to a class in function, but it is predefined, does not exist in the document tree, and is expressed in a different way, so it is called a pseudo class.
The content controlled by a pseudo element is the same as the content controlled by an element, but the pseudo element does not exist in the document tree and is not a real element, so it is called a pseudo element.
Pseudo classes include: :first-child, :link:, vistited, :hover:, active:focus, :lang
Pseudo elements include: :first-line, :first-letter , :before, :after
The difference between pseudo-class and pseudo-element:
pseudo-class
pseudo-class select element It is based on the current state of the element, or the current characteristics of the element, rather than static signs such as the element's id, class, and attributes.
Since the state changes dynamically, when an element reaches a specific state, it may get a pseudo-class style; when the state changes, it will lose this style. It can be seen from this that its function is somewhat similar to that of class, but it is based on abstraction outside of the document, so it is called a pseudo class.
:link
Pseudo class will be applied to unvisited links and is mutually exclusive with :visited.
:hover
Pseudo class will be applied to the element that the mouse pointer is hovering over.
:active
Pseudo class will be applied to activated elements, such as clicked links, pressed buttons, etc.
:visited
The pseudo class will be applied to links that have been visited, and is mutually exclusive with :link.
:focus
Pseudo class will be applied to elements that have keyboard input focus.
:first-child
The pseudo-class will be applied when the element first appears on the page.
:lang
The pseudo-class will be applied to elements with the specified lang.
Pseudo-element
Different from pseudo-classes that target elements in a special state, pseudo-elements operate on specific content in the element, and the levels it operates on are relatively Pseudo-classes are one level deeper and therefore much less dynamic than pseudo-classes.
In fact, the purpose of designing pseudo-elements is to select the first letter (letter) and first line of element content, and select the front or back of certain content, which is something that ordinary selectors cannot do. The content it controls is actually the same as the element, but it is only an abstraction based on the element and does not exist in the document, so it is called a pseudo element.
::first-letter
The style of the pseudo-element will be applied to the first letter (letter) of the element's text.
::first-line
The pseudo-element's style will be applied to the first line of the element's text.
::before
Add new content at the front of the element content.
::after
Add new content at the end of the element content.
::before and ::after are often used with CSS content generation.
The above is the detailed content of What do one colon and two colons mean in CSS?. For more information, please follow other related articles on the PHP Chinese website!
Hot AI Tools
Undress AI Tool
Undress images for free
Undresser.AI Undress
AI-powered app for creating realistic nude photos
AI Clothes Remover
Online AI tool for removing clothes from photos.
Clothoff.io
AI clothes remover
Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!
Hot Article
Hot Tools
Notepad++7.3.1
Easy-to-use and free code editor
SublimeText3 Chinese version
Chinese version, very easy to use
Zend Studio 13.0.1
Powerful PHP integrated development environment
Dreamweaver CS6
Visual web development tools
SublimeText3 Mac version
God-level code editing software (SublimeText3)
Hot Topics
What is Autoprefixer and how does it work?
Jul 02, 2025 am 01:15 AM
Autoprefixer is a tool that automatically adds vendor prefixes to CSS attributes based on the target browser scope. 1. It solves the problem of manually maintaining prefixes with errors; 2. Work through the PostCSS plug-in form, parse CSS, analyze attributes that need to be prefixed, and generate code according to configuration; 3. The usage steps include installing plug-ins, setting browserslist, and enabling them in the build process; 4. Notes include not manually adding prefixes, keeping configuration updates, prefixes not all attributes, and it is recommended to use them with the preprocessor.
How can you animate an SVG with CSS?
Jun 30, 2025 am 02:06 AM
AnimatingSVGwithCSSispossibleusingkeyframesforbasicanimationsandtransitionsforinteractiveeffects.1.Use@keyframestodefineanimationstagesforpropertieslikescale,opacity,andcolor.2.ApplytheanimationtoSVGelementssuchas,,orviaCSSclasses.3.Forhoverorstate-b
What is the conic-gradient() function?
Jul 01, 2025 am 01:16 AM
Theconic-gradient()functioninCSScreatescirculargradientsthatrotatecolorstopsaroundacentralpoint.1.Itisidealforpiecharts,progressindicators,colorwheels,anddecorativebackgrounds.2.Itworksbydefiningcolorstopsatspecificangles,optionallystartingfromadefin
CSS tutorial focusing on mobile-first design
Jul 02, 2025 am 12:52 AM
Mobile-firstCSSdesignrequiressettingtheviewportmetatag,usingrelativeunits,stylingfromsmallscreensup,optimizingtypographyandtouchtargets.First,addtocontrolscaling.Second,use%,em,orreminsteadofpixelsforflexiblelayouts.Third,writebasestylesformobile,the
CSS tutorial for creating loading spinners and animations
Jul 07, 2025 am 12:07 AM
There are three ways to create a CSS loading rotator: 1. Use the basic rotator of borders to achieve simple animation through HTML and CSS; 2. Use a custom rotator of multiple points to achieve the jump effect through different delay times; 3. Add a rotator in the button and switch classes through JavaScript to display the loading status. Each approach emphasizes the importance of design details such as color, size, accessibility and performance optimization to enhance the user experience.
What is feature detection in CSS using @supports?
Jul 02, 2025 am 01:14 AM
FeaturedetectioninCSSusing@supportschecksifabrowsersupportsaspecificfeaturebeforeapplyingrelatedstyles.1.ItusesconditionalCSSblocksbasedonproperty-valuepairs,suchas@supports(display:grid).2.Thismethodensuresfuturecompatibilityandavoidsrelianceonunrel
European virtual currency trading platform ranking list 2025 latest list TOP10 inventory (recently updated)
Jul 11, 2025 pm 08:57 PM
The top ten virtual currency trading platforms in Europe in 2025 include Binance, OKX, Coinbase, etc., and are selected based on compliance, security, expenses, asset types and user experience. 1. Binance: The world has the largest transaction volume, low fees, and has obtained a license in multiple countries; 2. OKX: Comprehensive products, strong technology, registered in France; 3. Coinbase: Compliance and safety, suitable for beginners, licensed in many countries; 4. Gate.io: Has a long history, high security, registered in many European countries; 5. Bitstamp: Founded early, has strong compliance, regulated by Luxembourg; 6. eToro: Supports social transactions, diversified investment, regulated by CySEC; 7. Bitpanda: World
Integrating CSS and JavaScript effectively with HTML5 structure.
Jul 12, 2025 am 03:01 AM
HTML5, CSS and JavaScript should be efficiently combined with semantic tags, reasonable loading order and decoupling design. 1. Use HTML5 semantic tags, such as improving structural clarity and maintainability, which is conducive to SEO and barrier-free access; 2. CSS should be placed in, use external files and split by module to avoid inline styles and delayed loading problems; 3. JavaScript is recommended to be introduced in front, and use defer or async to load asynchronously to avoid blocking rendering; 4. Reduce strong dependence between the three, drive behavior through data-* attributes and class name control status, and improve collaboration efficiency through unified naming specifications. These methods can effectively optimize page performance and collaborate with teams.


