search
HomeWeb Front-endCSS TutorialShare an interesting CSS3 pseudo-element::marker, which makes the list number more vivid

This article will introduce to you the interesting and interesting CSS3 pseudo-element ::marker. Using it can make our list numbers more interesting and vivid. If you are interested, come and take a look with me!

Share an interesting CSS3 pseudo-element::marker, which makes the list number more vivid

What is ::marker

CSS pseudo-element::marker is newly added starting from CSS Pseudo-Elements Level 3. A relatively new pseudo-element perfected in CSS Pseudo-Elements Level 4, it has been supported by browsers since Chrome 86. [Learning video sharing: css video tutorial]

Using it, we can add a pseudo element to the element to generate a bullet or number.

Normally, we have the following structure:

<ul>
  <li>Contagious</li>
  <li>Stages</li>
  <li>Pages</li>
  <li>Courageous</li>
  <li>Shaymus</li>
  <li>Faceless</li>
</ul>

No special style is added by default. Its style is roughly like this:

Share an interesting CSS3 pseudo-element::marker, which makes the list number more vivid

##Using

::marker we can transform the small dot in front of the serial number:

li {
  padding-left: 12px;
  cursor: pointer;
  color: #ff6000;
}
li::marker {
  content: &#39;>&#39;;
}

Then we can transform the small dot into anything we want:

Share an interesting CSS3 pseudo-element::marker, which makes the list number more vivid

::marker pseudo-element Some limitations

First of all, the element that can respond to

::marker can only be a list item, for example, the li inside ul and the li inside ol are both list item.

Of course, this does not mean that there is no way if we want to use it on other elements. Except for

list item, we can set any display: list-item The elements use the ::marker pseudo-element.

Secondly, for the styles within pseudo-elements, not all style properties can be used. Currently we can only use these:

  • all font properties -- So the font property is related
  • color -- color value
  • the content property -- content content, similar to ::before The content of the pseudo element is used to fill in the serial number content
  • text-combine-upright (en-US), unicode-bidi and direction properties -- related to the document writing direction
::Exploring some applications of marker

For example, we often see some decorations in front of the title:

Share an interesting CSS3 pseudo-element::marker, which makes the list number more vivid

Or, we can also use emoji expressions:

Share an interesting CSS3 pseudo-element::marker, which makes the list number more vivid

are all very suitable for display using

::marker. Note that is required when used on non-list-item elements. display: list-item

<h1 id="Lorem-nbsp-ipsum-nbsp-dolor-nbsp-sit-nbsp-amet">Lorem ipsum dolor sit amet</h1>
<h1 id="Lorem-nbsp-ipsum-nbsp-dolor-nbsp-sit-nbsp-amet">Lorem ipsum dolor sit amet</h1>

Share an interesting CSS3 pseudo-element::marker, which makes the list number more vivid

CodePen Demo -- ::marker example

https://codepen.io/ Chokcoco/pen/eYvZmpW

::marker can change dynamically

Interestingly,

::marker can still change dynamically, take advantage of this , you can easily create some interesting hover effects.

For example, if you are not selected, you will not be happy, but if you are selected, you will be happy:

Share an interesting CSS3 pseudo-element::marker, which makes the list number more vivid

Share an interesting CSS3 pseudo-element::marker, which makes the list number more vivid

##CodePen Demo -- ::marker example

https://codepen.io/Chokcoco/pen/eYvZmpW

Used together with counter

It can be observed that, The

::marker

pseudo-element is very similar to the ::before and ::after pseudo-elements. They all have a content attribute. . In

content

, some simple string addition operations can actually be performed. Using this, we can cooperate with CSS counters counter-reset and counter-increment to implement the operation of adding a serial number to the ::marker element. If you don’t know much about

counter-increment
, you can go here: MDN -- counter-increment Suppose we have the following HTML:
<h3 id="Lorem-nbsp-ipsum-nbsp-dolor-nbsp-sit-nbsp-amet">Lorem ipsum dolor sit amet.</h3>
<p>Lorem ipsum dolor sit amet consectetur adipisicing elit.</p>
<h3 id="Itaque-nbsp-sequi-nbsp-eaque-nbsp-earum-nbsp-laboriosam">Itaque sequi eaque earum laboriosam.</h3>
<p>Ratione culpa reprehenderit beatae quaerat voluptatibus, debitis iusto?</p>
<h3 id="Laudantium-nbsp-sapiente-nbsp-commodi-nbsp-quidem-nbsp-excepturi">Laudantium sapiente commodi quidem excepturi!</h3>
<p>Lorem ipsum dolor sit amet consectetur adipisicing elit.</p>

We use

::marker

and CSS counter counter-increment to implement an ordered list of automatic counting and h3 preceded by an emoji expression: The effect of <pre class='brush:php;toolbar:false;'>body { counter-reset: h3; } h3 { counter-increment: h3; display: list-item; } h3::marker { display: list-item; content: &quot;✔&quot; counter(h3) &quot; &quot;; color: lightsalmon; font-weight: bold; }</pre> is as follows, which implements the effect of automatically adding a serial number to the

::marker

element:

Share an interesting CSS3 pseudo-element::marker, which makes the list number more vivid

CodePen Demo -- ::marker example

https://codepen.io/chriscoyier/pen/ExNWmee

Finally

This article introduces what ::marker is and some of its practical scenarios. It can be seen that although ::before, ::after can also achieve similar functions, but CSS still provides a more semantic tag ::marker, which also shows that everyone needs to control their own front-end code (HTML/CSS) Pay more attention to semantics.

Okay, this article ends here, I hope it will be helpful to you :)

For more programming-related knowledge, please visit: Programming Video! !

The above is the detailed content of Share an interesting CSS3 pseudo-element::marker, which makes the list number more vivid. For more information, please follow other related articles on the PHP Chinese website!

Statement
This article is reproduced at:segmentfault. If there is any infringement, please contact admin@php.cn delete
css怎么隐藏元素但不占空间css怎么隐藏元素但不占空间Jun 01, 2022 pm 07:15 PM

两种方法:1、利用display属性,只需给元素添加“display:none;”样式即可。2、利用position和top属性设置元素绝对定位来隐藏元素,只需给元素添加“position:absolute;top:-9999px;”样式。

原来利用纯CSS也能实现文字轮播与图片轮播!原来利用纯CSS也能实现文字轮播与图片轮播!Jun 10, 2022 pm 01:00 PM

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

css3如何实现鼠标点击图片放大css3如何实现鼠标点击图片放大Apr 25, 2022 pm 04:52 PM

实现方法:1、使用“:active”选择器选中鼠标点击图片的状态;2、使用transform属性和scale()函数实现图片放大效果,语法“img:active {transform: scale(x轴放大倍数,y轴放大倍数);}”。

css3什么是自适应布局css3什么是自适应布局Jun 02, 2022 pm 12:05 PM

自适应布局又称“响应式布局”,是指可以自动识别屏幕宽度、并做出相应调整的网页布局;这样的网页能够兼容多个不同的终端,而不是为每个终端做一个特定的版本。自适应布局是为解决移动端浏览网页而诞生的,能够为使用不同终端的用户提供很好的用户体验。

css3动画效果有变形吗css3动画效果有变形吗Apr 28, 2022 pm 02:20 PM

css3中的动画效果有变形;可以利用“animation:动画属性 @keyframes ..{..{transform:变形属性}}”实现变形动画效果,animation属性用于设置动画样式,transform属性用于设置变形样式。

css3怎么设置动画旋转速度css3怎么设置动画旋转速度Apr 28, 2022 pm 04:32 PM

在css3中,可以利用“animation-timing-function”属性设置动画旋转速度,该属性用于指定动画将如何完成一个周期,设置动画的速度曲线,语法为“元素{animation-timing-function:速度属性值;}”。

css3线性渐变可以实现三角形吗css3线性渐变可以实现三角形吗Apr 25, 2022 pm 02:47 PM

css3线性渐变可以实现三角形;只需创建一个45度的线性渐变,设置渐变色为两种固定颜色,一个是三角形的颜色,另一个为透明色即可,语法“linear-gradient(45deg,颜色值,颜色值 50%,透明色 50%,透明色 100%)”。

一文了解CSS3中的新特性 ::target-text 选择器一文了解CSS3中的新特性 ::target-text 选择器Apr 12, 2022 am 11:24 AM

本篇文章带大家一起深入了解一下CSS3中的新特性::target-text 选择器,聊聊该选择器的作用和使用方法,希望对大家有所帮助!

See all articles

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

Repo: How To Revive Teammates
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

WebStorm Mac version

WebStorm Mac version

Useful JavaScript development tools

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.