随笔 - 366  文章 - 0  评论 - 392

::before和::after伪元素的用法

一、介绍

css3为了区分伪类和伪元素,伪元素采用双冒号写法。

常见伪类——:hover,:link,:active,:target,:not(),:focus。

常见伪元素——::first-letter,::first-line,::before,::after,::selection。

::before和::after下特有的content,用于在css渲染中向元素逻辑上的头部或尾部添加内容。

这些添加不会出现在DOM中,不会改变文档内容,不可复制,仅仅是在css渲染层加入。

所以不要用:before或:after展示有实际意义的内容,尽量使用它们显示修饰性内容,例如图标。

举例:网站有些联系电话,希望在它们前加一个icon☎,就可以使用:before伪元素,如下:

<!DOCTYPE html>
<meta charset="utf-8" />
<style type="text/css">.phoneNumber::before {content:'\260E';font-size: 15px;
}
</style>
<p class="phoneNumber">12345645654</p>

Note:这些特殊字符的html,js和css的写法是不同的,具体可查看html特殊字符的html,js,css写法汇总。

二、content属性

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

content可取以下值。

1、string

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

举例:

<!DOCTYPE html>
<meta charset="utf-8" />
<style type="text/css">
p::before{content: "《";color: blue;
}
p::after{content: "》";color: blue;
}
</style>
<p>平凡的世界</p>

2、attr()

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

<style type="text/css">
a::after{content: "(" attr(href) ")";
}
</style>
<a href="http://www.cnblogs.com/starof">starof</a>

3、url()/uri()

用于引用媒体文件。

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

<style>
a::before{content: url("https://www.baidu.com/img/baidu_jgylogo3.gif");
}
a::after{content:"("attr(href)")";
}
a{text-decoration: none;
}
</style>
---------------------------
<body>
<a href="http://www.baidu.com">百度</a>
</body>    

效果:

4、counter()

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

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

h2:before { counter-increment: chapter; content: "Chapter " counter(chapter) ". " }

代码:

<style>
body{counter-reset: section;
}
h1{counter-reset: subsection;
}
h1:before{counter-increment:section;content:counter(section) "、";
}
h2:before{counter-increment:subsection;content: counter(section) "." counter(subsection) "、";
}
</style>
------------------------------------------------
<body>
<h1>HTML tutorials</h1>
<h2>HTML Tutorial</h2>
<h2>XHTML Tutorial</h2>
<h2>CSS Tutorial</h2><h1>Scripting tutorials</h1>
<h2>JavaScript</h2>
<h2>VBScript</h2><h1>XML tutorials</h1>
<h2>XML</h2>
<h2>XSL</h2></body>   

效果:

了解更多可参考:https://developer.mozilla.org/en-US/docs/Web/Guide/CSS/Counters

三、使用

1、清除浮动

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

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

2、模拟float:center的效果

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

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

核心css如下:

#page-wrap { width: 60%; margin: 40px auto; position: relative; }
#logo { position: absolute; top: 0; left: 50%; margin-left: -125px; }
#l, #r { width: 49%; }
#l { float: left; }
#r { float: right; }
#l:before, #r:before { content: ""; width: 125px; height: 250px; }
#l:before { float: right; }
#r:before { float: left; }

完整代码如下:

  View Code

出自:https://css-tricks.com/float-center/

3、做出各种图形效果

举例:一个六角星

<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>

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

点我查看更多。

4、不使用图片创建小图标

举例:比如一个电话

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

<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>
<div id="wraper"><div id="phone"></div>
</div>

更多图标:

  View Code

这个效果来自:http://www.w3cfuns.com/blog-5444604-5402127.html

有大神用伪元素创建了84种小图标,具体可查看http://nicolasgallagher.com/pure-css-gui-icons/

5、显示打印网页的URL

<style>
@media print {a[href]:after {content: " (" attr(href) ") ";}
}
</style><body>
<a href="http://www.baidu.com">百度</a>
</body>  

6、给blockquote添加引号

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

<meta charset="utf-8"/>
<style type="text/css">blockquote::before {content: open-quote;color: #ddd;z-index: -1;font-size:80px;
}
</style>
<blockquote>引用一个段落,双引号用::before伪元素实现</blockquote>

7、超链接特效

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

<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>
<a>鼠标移上去出现方括号</a>

更多创意链接特效可参考: Creative Link Effects 。

8、::before和::after实现多背景图片

举例:一个标签应用5张背景图

  View Code

原效果来自:Multiple Backgrounds and Borders with CSS 2.1

这个效果看的真的是脑洞大开,虽然多背景图用css3的background-image很容易就能实现。但是这篇文章是10年写的,已经过去5年了,想想也正是他们这样的尝试和努力才加速了css3标准的制定,让今天的开发更easy。今天的我们又能为5年后的开发人员做些什么贡献呢?

本文作者starof,因知识本身在变化,作者也在不断学习成长,文章内容也不定时更新,为避免误导读者,方便追根溯源,请诸位转载注明出处:http://www.cnblogs.com/starof/p/4459991.html有问题欢迎与我讨论,共同进步。

转载于:https://www.cnblogs.com/ysq2018China/p/10298405.html

HTML:::before和::after伪元素的用法相关推荐

  1. :before、:after伪元素的用法 !

    :after 伪元素在元素之后添加内容. :before伪元素在元素之前添加内容. 这个伪元素允许创作人员在元素内容的最后面插入生成内容.默认地,这个伪元素是行内元素,不过可以使用属性 dispiay ...

  2. 细数CSS伪元素及其用法

    引言 CSS中有两个很常见的概念,伪类和伪元素. 伪类用于在页面中的元素处于某个状态时,为其添加指定的样式. 伪元素会创建一个抽象的伪元素,这个元素不是DOM中的真实元素,但是会存在于最终的渲染树中, ...

  3. ::before和::after伪元素的用法

    一.介绍 css3为了区分伪类和伪元素,伪元素采用双冒号写法. 常见伪类--:hover,:link,:active,:target,:not(),:focus. 常见伪元素--::first-let ...

  4. 伪元素学习包含::before、::after的用法

    <!-- 伪元素的学习(伪类元素就是页面代码不会出现伪类元素) 1.::before  before和after主要是配合content属性使用的 2.::after 3.css content ...

  5. 基础知识--:before伪元素和:after伪元素

    http://book.51cto.com/art/201108/285688.htm 3.7  替换指定位置 大家都知道before和after是前.后的意思.但是奇怪的是,CSS中的:before ...

  6. 修改after样式_理解:Before和:After伪元素

    CSS样式表的主要作用是修饰Web页面上的HTML标记,但有时候,为了实现某个效果而往页面里反复添加某个HTML标记很繁琐,或者是显得多余,或者是由于某种原因而做不到.这就是CSS伪元素(Pseudo ...

  7. CSS:理解:Before和:After伪元素

    CSS样式表的主要作用是修饰Web页面上的HTML标记,但有时候,为了实现某个效果而往页面里反复添加某个HTML标记很繁琐,或者是显得多余,或者是由于某种原因而做不到.这就是CSS伪元素(Pseudo ...

  8. css空心三角形_(12)把“可以动的盒子”更优雅地展示: “伪元素”妙用 | CSS...

    原创:itsOli @前端一万小时 本文版权归作者所有,未经授权,请勿转载! 本文节选自"语雀"私有付费专栏「前端一万小时 | 从零基础到轻松就业」 1. 如何使用伪元素来清除浮动 ...

  9. 【CSS进阶】伪元素的妙用--单标签之美

    正文从这里开始,本文主要讲述一下 伪元素 before 和 after 各种妙用.    :before和::before的区别 在介绍具体用法之前,简单介绍下伪类和伪元素.伪类大家听的多了,伪元素可 ...

最新文章

  1. java 跳转 oop_Java基础之:OOP——接口
  2. 一个10转14进制的代码(写的很巧)
  3. 步步为营VS 2008 + .NET 3.5系列文章索引
  4. 在带有组合框的值列表的下拉列表中显示显示属性的子集
  5. php-fpm初始化失败,FPM的初始化 - [ PHP7的内核剖析 ] - 在线原生手册 - php中文网
  6. STM32 I2C通信(读写eeprom)
  7. 高性能HTTP加速器Varnish(性能调优篇)
  8. MinGW GCC 7.1.0 2017年6月份出炉啦
  9. C#:使用dsoframer.ocx控件实现内嵌office效果(详解)
  10. 七 代码检查工具安装
  11. 台式计算机 无线已连接 无法上网,WiFi已连接不可上网怎么办
  12. oracle 终止imp,终止imp/exp和expdp/impdp进程运行的方法
  13. 判定重大风险有哪几种_重大危险源判定
  14. 【转帖】Dirichlet Distribution(狄利克雷分布)与Dirichlet Process(狄利克雷过程)原文https://www.datalearner.com/blog/10514
  15. VB连接Sql Server,Oracle,SyBase,Access数据库操作实例
  16. 加一度推荐超实用的7大拓词工具
  17. 机械与计算机大一学的一样吗,机械设计制造及其自动化专业各校大一新生学的课程一样吗...
  18. ios 调用 H5页面中含有百度地图,地图不显示
  19. 【金融】银行间质押式回购
  20. jenkins+sonar 实现代码检测

热门文章

  1. 【算法】斐波那契数列与跳台阶
  2. android与苹果 推送,科普下安卓和苹果的推送区别
  3. 苹果系统和安卓系统的区别_安卓系统用久了会卡,苹果系统就能一直流畅?
  4. The Tomcat connector configured to listen on port xxxxx failed to start.The port may already be used
  5. 【Ubuntu】Ubuntu中安装yum
  6. 你所不知道的Lint
  7. matlab运行一直正忙,MATLAB运行时一直处于忙的状态,是不是程序存在死循环
  8. 运筹学 $2 运输问题
  9. Hive分区表数据压缩
  10. location.href不跳转、不执行的最有效的解决办法!