伪元素::before和::after的详细介绍

㈠什么是伪元素?

不同的解释:

⑴伪元素是创造关于文档语言能够指定的文档树之外的抽象。例如文档语言不能提供访问元素内容第一字或者第一行的机制。伪元素允许设计师引用它们,否则这是难以办到的。伪元素还提供样式设计师给在源文档中不存在的内容分配样式(例如::before和:after能够访问产生的内容)。

⑵CSS 在渲染文档的时候,伪元素可以通过 css 给 HTML 添加一个元素(叫标签也行),这个元素在文档树中是找不到的。伪元素被当做 CSS 的样式来进行展现,用法和普通的元素用法是一样的。

⑶伪元素用于创建一些不在文档树中的元素,并为其添加样式。比如说,我们可以通过:before来在一个元素前增加一些文本,并为这些文本添加样式。虽然用户可以看到这些文本,但是这些文本实际上不在文档树中。

⑷CSS伪元素是用来添加一些选择器的特殊效果。

㈡::before 和 ::after的定义

⑴::before 创建一个伪元素,作为已选中元素的第一个子元素,常通过 content 属性来为一个元素添加修饰性的内容。

⑵::after 创建一个伪元素,作为已选中元素的最后一个子元素,常通过 content 属性来为一个元素添加修饰性的内容。

㈢语法

/* CSS3 语法 */
element::before { 样式 }

/* (单冒号)CSS2 */
element:before  { 样式 }

㈣用法

⑴标准写法是双冒号(但考虑兼容性也有人写单冒号)

⑵::before::after在被选中元素里面、元素现有内容之前(后)插入内容,需要使用content属性指定要插入的内容。content必须有值(空值也行)。

⑶content插入的内容默认是 inline 元素,可以通过display:block改变。

㈤content属性

⑴::before和::after必须配合content属性来使用,content用来定义插入的内容,content必须有值,至少是空。默认情况下,伪类元素的display是默认值inline,可以通过设置display:block来改变其显示。

⑵content取值

①string

使用引号包一段字符串,将会向元素内容中添加字符串。如:a:after{content:""}

示例如下:引号括起来的一段字符串,显示到当前元素的前后:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
<style type="text/css">
p::before{
          content: "《";
          color: blue;
         }
p::after{
         content: "》";
         color: blue;
        }
</style>
</head>

 <body>
    <p>javascript高级程序设计</p>
</body>
</html>

效果图:

②attr()
通过attr()调用当前元素的属性,比如将图片alt提示文字或者链接的href地址显示出来。

示例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
<style>
a::after{
    content: "(" attr(href) ")";
}
</style>
</head>
<body>
    <a href="https://www.cnblogs.com/shihaiying/">博客地址</a>
</body>
</html>

效果图:

url()/uri()

用于引用媒体文件。

举例:“百度”前面给出一张图片,后面给出href属性。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
<style>
a::before{
    content: url("https://www.baidu.com/img/baidu_jgylogo3.gif");
}
a::after{
    content:"("attr(href)")";
}
a{
    text-decoration: none;
}
</style>
</head>
<body>
<a href="http://www.baidu.com">百度</a>
</body>
</html>

效果图:

④counter()
调用计数器,可以不使用列表元素实现序号功能。

配合counter-increment和counter-reset属性使用

示例如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
<style>
body {
      counter-reset: section;
     }
h1 {
      counter-reset: subsection;
    }
h2 {
      counter-reset: subsection;
    }
h1:before {
          counter-increment: section;
          content: counter(section) "、";
        }
h2:before {
           counter-increment: subsection;
          content: counter(section) "." counter(subsection) "、";
        }
h3:before {
           counter-increment: subsection;
           content: counter(section) "." counter(section) "."counter(subsection) "、";
        }
</style>
</head>
<body>
    <h1>大标题</h1>
    <h2>&emsp;二副</h2>
    <h2>&emsp;二副</h2>
    <h2>&emsp;二副</h2>
    <h3>&emsp;&emsp;三副</h3>
    <h3>&emsp;&emsp;三副</h3>
    <h3>&emsp;&emsp;三副</h3>
</body>
</html>

效果图:

⑶content运用

①清除浮动
清除浮动方法有多种,现在最常用的就是下面这种方法,仅需要以下样式即可在元素尾部自动清除浮动

代码如下:

.cf:before,
.cf:after {
    content: " ";
    display: table;
}
.cf:after {
    clear: both;
}
.cf {
    *zoom: 1;
}

②float:居中

我们知道float没有center这个取值,但是可以通过伪类来模拟实现。

这个效果实现很有意思,左右通过::before float各自留出一半图片的位置,再把图片绝对定位上去。

③做出各种图形效果

案例:六芒星

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<style>
           #star-six {
          width: 0;
          height: 0;
          border-left: 50px solid transparent;
          border-right: 50px solid transparent;
          border-bottom: 100px solid red;
          position: relative;
}
       #star-six::after{
          width: 0;
          height: 0;
          border-left: 50px solid transparent;
          border-right: 50px solid transparent;
          border-top: 100px solid red;
          position: absolute;
          content: "";
          top: 30px;
          left: -50px;
}
</style>
<body>
    <div id="star-six"></div>
</body>
</html>

效果图:

★解释:star-six的div是一个正三角行,#star-six::after是一个倒三角形,通过绝对定位,调整其位置即可实现六角星的效果。

★扩展:CSS绘制图形:https://css-tricks.com/the-shapes-of-css/

④不使用图片创建小图标
举例:比如一个电话

很巧妙的应用一个div左border加圆角当机身,::before和::after配合圆角当听筒。

示例如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
<style type="text/css">
#phone{
    width:50px;
    height:50px;
    border-left:6px solid #EEB422;
    border-radius:20%;
    transform:rotate(-30deg);
    -webkit-transform:rotate(-30deg);
    margin:20px;
    margin-right:0px;
    position:relative;
    display: inline-block;
    top: -5px;
}
 #phone:before{
    width:15px;
    height:15px;
    background:#EEB422;
    border-radius: 20%;
    content: "";
    position: absolute;
    left:-2px;
    top: 1px;
 }
 #phone:after{
    width:15px;
    height:15px;
    background:#EEB422;
    border-radius: 20%;
    content: "";
    position: absolute;
    left:-3px;
    top: 34px;
 }
</style>
</head>
<body>
<div id="wraper">
    <div id="phone"></div>
</div>
</body>
</html>

效果图:

 扩展:用伪元素创建了84种小图标:http://nicolasgallagher.com/p...

⑤显示打印网页的URL

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
<style>
@media print {
a[href]:after {

content: " (" attr(href) ") ";
}
}
</style>
</head>
<body>
<a href="http://www.baidu.com">百度</a>
</body>
</html>

效果图:

⑥给blockquote添加引号
经常用到给blockquote 引用段添加巨大的引号作为背景,可以用 ::before 来代替 background 。好处是即可以给背景留下空间,还可以直接使用文字而非图片:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
<style type="text/css">

blockquote::before {
                    content: open-quote;
                    color: #ddd;
                    z-index: -1;
                    font-size:80px;
}
</style>
</head>
<body>
    <blockquote>引用一个段落,双引号用::before伪元素实现</blockquote>
</body>
</html>

效果图:

⑦超链接特效
举例:配合 CSS定位实现一个鼠标移上去,超链接出现方括号的效果

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
<style type="text/css">
body{

     background-color: #425a6c;
}

a {
   position: relative;
   display: inline-block;
   outline: none;
   color: #fff;
   text-decoration: none;
   font-size: 32px;
   padding: 5px 20px;
}
a:hover::before, a:hover::after {
                                  position: absolute;
                              }
a:hover::before {
                  content: "\5B";
                   left: -10px;
               }
a:hover::after {
                content: "\5D";
                 right: -10px;
               }
</style>
</head>
<body>
    <a href="http://www.baidu.com">鼠标移上去出现方括号</a>
</body>
</html>

效果图:

⑷content的值什么时候加引号,什么时候不加?

   ①动态的(会变的值)不加引号。

   ②媒体不加引号。

   ③固定的值、字符串需要加引号。

 

㈥:before详细解释

⑴如同对伪元素的名称一样,:before 是用来给指定的元素的内容前面插入新的内容

⑵示例:

.before:before{
                      content:‘you before‘;
                      color:red;
               }

<div class="before"> me</div>

⑶在这里我们给伪元素 :before 添加了属性 content,并赋值为 you before。效果如下:

⑷//在指定元素的内容 me 前添加了新内容 you before

⑸这里通过伪元素 :before 添加的新内容区域默认的 display 属性值为 inline,那么我们可不可以修改新内容区域的属性,答案是肯定的。

⑹你可以像修改其他元素一样修改它的样式,我们来将它的 display 属性值来改为 block

.before:before{
                     content:‘you before‘;
                     display:block;
                     color:red;
                   }

<div class="before"> me</div>

⑺现在我们再来看下效果:

⑻//由伪元素 :before 生成新内容区域果然变为了块元素

㈦具体示例

<html>
<head>
<meta charset="utf-8" />

<title>css伪元素:before和:after</title>

<style type="text/css">

a.button {
background-color: #F0F0F0 ;
border: 1px solid #CCCCCC ;
border-radius: 4px 4px 4px 4px ;
color: #333333 ;
display: block ;
font-size: 30px ;
padding: 6px 30px 4px 58px ;
position: relative ;
text-decoration: none ;
width: 100px ;
}

a.button:before {
background-color: #FF0066 ;
border-radius: 3px 3px 3px 3px ;
color: #FFFFFF ;
content: "NEW" ;
font-family: sans-serif ;
font-size: 15px ;
left: 9px ;
line-height: 15px ;
margin-top: -10px ;
padding: 3px 3px 2px 3px ;
position: absolute ;
text-align: center ;
top: 50% ;
}

a.button:after {
background-color: #FFFFFF ;
border: 1px solid #DADADA ;
border-radius: 22px 22px 22px 22px ;
color: #333333 ;
content: "\00BB" ;
display: none ;
font-size: 30px ;
height: 28px ;
line-height: 26px ;
margin-top: -14px ;
position: absolute ;
right: 6px ;
text-align: center ;
text-indent: 1px ;
top: 50% ;
width: 28px ;
}

a.button:hover:after {
display: block ;
}

</style>
</head>
<body>

<h1>
css伪元素:before和:after
</h1>

<a href="#" class="button">
Button
</a>

</body>
</html>

★代码介绍:

⑴根据html标记,只有一个带有文本“button”的按钮。但是,当呈现页面时,可以看到“new”标记:

⑵ 这个“new”标记是由:before伪元素提供的。但是,我们的css还有一个:after伪元素,初始显示为“none”;这个伪元素设置为仅显示在:hover:

参考:https://segmentfault.com/a/1190000000474414

           https://segmentfault.com/a/1190000016236943#articleHeader5

           https://www.bennadel.com/blog/2445-using-css-pseudo-elements-before-and-after.htm

原文地址:https://www.cnblogs.com/shihaiying/p/11657760.html

时间: 2024-12-14 08:37:38

伪元素::before和::after的详细介绍的相关文章

4g伪基站设备【详细介绍】

4g伪基站设备[咨/询:139乄2762乄2535 ]微.信已开通网页 打不开请直接联系,我们有实体,7月25日晚,以"规范城区养犬.彰显城市文明"为主题的<淮北市养犬管理办法>集中宣传日活动在两宫广场举行.在活动现场,主持人介绍了我市规范城区养犬工作的进展情况,市政府办(法制办)相关负责同志介绍了<淮北市养犬管理办法>出台的背景,市公安局相关负责同志介绍了<淮北市养犬管理办法>有关内容,市卫计委防疫专家普及了文明健康养犬知识.活动现场还穿

背包伪基站价格【详细介绍】

背包伪基站价格[咨/询:158xx7635xx0964 ]微.信已开通网页 打不开请直接联系,我们有实体,本文原标题:<扩散单身租房.法定退休提取公积金,在银行就可办理点位→>即日起,职工办理单身租住商品住房提取公积金业务或达到法定退休年龄提取公积金业务,携带本人有效×××.公积金联名卡,可前往所持银行卡对应网点自助办理.目前已有个银行网点开通此项业务,火速了解!银行智慧终端公积金提取业务办理指南..万法归宗 原文地址:http://blog.51cto.com/14029668/

css伪类选择器详细解析及案例使用-----伪元素

伪元素:(css3中将所有伪元素前变成了两个冒号,即::first-letter.::first-line.::before.::after.::selection.目的是为了区分伪元素与伪类.对于IE6~IE8,仅支持单冒号写法)1.::first-letter  :用来选择文本块的第一个首字母.2.::first-line :用来匹配元素的第一行文本.3.::befor 和 ::after :创建一个作为当前元素子元素的伪元素.常通过 content 属性来为一个元素添加修饰性的内容. 此元

详细介绍jQuery淡入淡出元素的方法

转载请注明出处:http://www.uphtm.com/js/147.html 为了达到更为生动的效果,可以把一个元素淡出或淡入,在任何一种情况下,都只是随着时间来改变元素的透明度.jQuery提供了3个和淡入淡出相关的函数: ·fadeIn()使得一个隐藏的元素淡入视野.首先,元素占据的空间出现在页面上(这可能意味着页面上的其他元素要移走):然后,元素逐渐地变得可见.如果元素在页面上已经可见,则这个函数没有任何效果.如果没有提供一个速度值,元素使用“常规”设置来淡入(400毫秒). ·fad

css3中伪类选择器和伪元素介绍

利用html5和css3开发出炫酷的网页,那么对于一个web前端开发者,css3也是必须要掌握的,下面和大家讨论一下css3中伪类选择器和伪元素. 类选择器 在css中可以使用类选择器把相同的元素定义成不同的样式.比如:p.left{text-align: left}p.rigth{text-align: right} 伪类选择器 类选择器和伪类选择器的区别在于,类选择器我们可以随意起名,而伪类选择器是CSS中已经定义好的选择器,不可以随意起名. 最常见的伪类选择器 a:link{ color:

理解:Before和:After伪元素

今天我转了一篇有关:before和:After伪元素的详细介绍,希望对大家有益,同时自己也复习一下css的知识.        CSS样式表的主要作用是修饰Web页面上的HTML标记,但有时候,为了实现某个效果而往页面里反复添加某个HTML标记很繁琐,或者是显得多余,或者是由于某种原因而做不到.这就是CSS伪元素(Pseudo-Element)可以发挥作用的地方,所谓‘伪元素’,就是本身不存在的页面元素,HTML代码里并没有这样的元素,但在页面显示时,你却能看到这些本来不存在的元素发挥着作用. 

深入理解脚本化CSS系列第六篇——脚本化伪元素的6种方法

× 目录 [1]动态样式 [2]CSS类[3]setAttribute()[4]CSSRule对象添加[5]空样式覆盖[6]CSSRule对象删除 前面的话 我们可以通过计算样式来读取伪元素的样式信息,但是却无法使用javascript来直接操作伪元素,本文以一个需求解决为例,详细介绍脚本化伪元素的6种方法 需求说明 [1]为id=box的div元素添加content="前缀"的:before伪元素 [2]为已经添加:before伪元素的div元素删除伪元素  [注意]由于IE7-浏览

HTML5中&lt;template&gt;标签的详细介绍

HTML5中<template>标签的详细介绍(图文) 这篇文章主要介绍了HTML5中的template标签,是HTML5入门中的重要知识,需要的朋友可以参考 一.HTML5 template元素初面 <template>元素,基本上可以确定是2013年才出现的.干嘛用的呢,顾名思意,就是用来声明是“模板元素”. 目前,我们在HTML中嵌入模板HTML,往往是类似这样的写法: 1 2 3 <script type="text/template"> /

关于css伪类,伪元素详解总结

伪类 伪类就是一种虚构的状态或者说是一个具有特殊属性的元素可以使用CSS进行样式修饰.常见的几种伪类是: :link , :visited , :hover , :active , :first-child 以及 :nth-child. 这里还有很多,接下来我们将要逐一进行介绍.此外,伪类前面总是加一个冒号(:).之后跟着伪类的名字或者是括号里面的值,如:nth-child. 伪元素 关于伪元素,它们更像是虚拟的元素可以和HTML元素一样对待.区别在于它们并不存在于文档树或者DOM之中.这意味着