首页 > 网页制作 > 心得技巧 > 正文

那些你所不知的CSS ::before 和::after 伪元素用法_心得技巧_网页制作

2018-11-22 21:06:49

CSS 有两个说不上常用的伪类 :before 和 :after,偶尔会被人用来添加些自定义格式什么的,但是它们的功用不仅于此。前几天发现了 Creative Link Effects 这个非常有意思的介绍创意链接特效的页面,里面惊人的效果大量使用到的特性除了 transform 属性进行变形之外,就是接下来要介绍的这两个伪元素了。

Creative Button Styles

Creative Button Styles

 一 基本语法

在了解进阶的应用之前,先来了解一下语法规则。平常仅仅需要将这两个伪元素用于添加一些自定义字符时,只需使用伪类使用的单冒号写法,以保证浏览器的兼容性:

CSS Code复制内容到剪贴板
  1. p:before  {}    

不过,在 CSS3 中为了区别伪元素和伪类为伪元素使用了双冒号,因此如果使用了 display 或者 width 等属性时使得显示脱离了原本元素后,建议按照标准双写。过于老的浏览器可能会存在支持问题,不过伪元素大多是配合 CSS3 使用,就无所谓向下兼容了:

CSS Code复制内容到剪贴板
  1. img::after {}     

这两个伪类下特有的属性 content ,用于在 CSS 渲染中向元素逻辑上的头部或尾部添加内容。注意这些添加不会改变文档内容,不会出现在 DOM 中,不可复制,仅仅是在 CSS 渲染层加入。比较有用的是以下几个值:

•[String] - 使用引号包括一段字符串,将会向元素内容中添加字符串。示例:

CSS Code复制内容到剪贴板
  1. •a:after { content""; }     
attr() – 调用当前元素的属性,可以方便的比如将图片的 Alt 提示文字或者链接的 Href 地址显示出来。示例:
CSS Code复制内容到剪贴板
  1. •a:after { content:"(" attr(href) ")"; }     
url() / uri() – 用于引用媒体文件。示例:
CSS Code复制内容到剪贴板
  1. •h1::before { contenturl(logo.png); }     
counter() –  调用计数器,可以不使用列表元素实现序号功能。具体请参见 counter-increment 和 counter-reset 属性的用法。示例:
CSS Code复制内容到剪贴板
  1. h2:before { countercounter-increment: chapter; content"Chapter " counter(chapter) ". " }   

二 进阶技巧

清除浮动是一个时常会遇到的问题,不少人的解决办法是添加一个空的 div 应用 clear:both; 属性。现在,无需增加没有意义的元素,仅需要以下样式即可在元素尾部自动清除浮动:

CSS Code复制内容到剪贴板
  1. .clear-fix { *overflowhidden; *zoom: 1; }     
  2. .clear-fix:after { display: table; content""width: 0; clearboth; }     

许多人喜欢给 blockquote 引用段添加巨大的引号作为背景,这种时候我们就可以用 :before 来代替 background 了,即可以给背景留下空间,还可以直接使用文字而非图片:

CSS Code复制内容到剪贴板
  1. blockquote::before {     
  2.     contentopen-quote;     
  3.     positionabsolute;     
  4.     z-index: -1;     
  5.     color#DDD;     
  6.     font-size120px;     
  7.     font-familyserif;     
  8.     font-weightbolder;     
  9. }    

 三 特效妙用

除了简单的添加字符,配合 CSS 强大的定位和特效特性,完全可以达到给简单的元素另外附加最多两个容器的效果。有一点需要注意的是,如果不需要内容仅配合样式属性做出效果,内容属性也不能为空,即 content:”" 。否则,其他的样式属性一概不会生效。

悬浮出现方括号

悬浮出现方括号

鼠标移上链接,出现方括号:

CSS Code复制内容到剪贴板
  1. a {     
  2.     positionrelative;     
  3.     displayinline-block;     
  4.     outlinenone;     
  5.     text-decorationnone;     
  6.     color#000;     
  7.     font-size32px;     
  8.     padding5px 10px;     
  9. }     
  10.      
  11. a:hover::before, a:hover::after { positionabsolute; }     
  12. a:hover::before { content"/5B"left: -20px; }     
  13. a:hover::after { content"/5D"rightright:  -20px; }     

同样,我们只需要配合 display: block 和 position: absolute ,就可以将其当成两个容器,拼合成悬浮出现双边框的特效:

CSS Code复制内容到剪贴板
  1. a {     
  2.     positionrelative;     
  3.     displayinline-block;     
  4.     outlinenone;     
  5.     text-decorationnone;     
  6.     color#000;     
  7.     font-size32px;     
  8.     padding: 0 10px;     
  9. }     
  10.      
  11. /* 大框 */     
  12. a:hover::before, a:hover::after {      
  13.     content"";     
  14.     displayblock;     
  15.     positionabsolute;     
  16.     top: -15%%;     
  17.     left: -14%%;     
  18.     width: 120%;     
  19.     height: 120%;     
  20.     border-stylesolid;     
  21.     border-width4px;     
  22.     border-color#DDD;     
  23.  }     
  24.      
  25. /* 小框 */     
  26.  a:hover::after {     
  27.     top: 0%;     
  28.     left: 0%;     
  29.     width: 100%;     
  30.     height: 100%;     
  31.     border-width2px;     
  32.  }    

以上这篇那些你所不知的CSS ::before 和::after 伪元素用法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

原文地址:http://www.cnblogs.com/androidshouce/archive/2016/06/12/5576493.html

  • 相关标签:心得技巧
  • 本文发布HTML5中文学习网 ,转载请注明出处,感谢您!
  • 相关文章


  • 曝网友假装外国人写投诉信 ofo秒退押金并回函致歉
  • 苹果市值缩水逾2000亿美元 遭多家投行下调目标价
  • Asp.net Core与类库读取配置文件信息的方法_实用技巧
  • asp.net在Repeater嵌套的Repeater中使用复选框详解_实用技巧
  • 利用IIS调试ASP.NET网站程序的完整步骤_实用技巧
  • Asp.Net Core轻松学习系列之配置文件_实用技巧
  • ASP.NET 页生命周期概述(小结)_实用技巧
  • 详解ASP.NET Core WebApi 返回统一格式参数_实用技巧
  • 2018年网络流行语有哪些?2018年十大网络流行语盘点
  • 华为首席财务官孟晚舟被暂扣 深圳市政府要求加方立即放人!
  • 独孤九贱(4)_PHP视频教程

    江湖传言:PHP是世界上最好的编程语言。真的是这样吗?这个梗究竟是从哪来的?学会本课程,你就会明白了。 PHP中文网出品的PHP入门系统教学视频,完全从初学者的角度出发,绝不玩虚的,一切以实用、有用...

    独孤九贱(5)_ThinkPHP5视频教程

    ThinkPHP是国内最流行的中文PHP开发框架,也是您Web项目的最佳选择。《php.cn独孤九贱(5)-ThinkPHP5视频教程》课程以ThinkPHP5最新版本为例,从最基本的框架常识开始,将...

    独孤九贱(1)_HTML5视频教程

    《php.cn原创html5视频教程》课程特色:php中文网原创幽默段子系列课程,以恶搞,段子为主题风格的php视频教程!轻松的教学风格,简短的教学模式,让同学们在不知不觉中,学会了HTML知识。 ...

    ThinkPHP5实战之[教学管理系统]

    本套教程,以一个真实的学校教学管理系统为案例,手把手教会您如何在一张白纸上,从零开始,一步一步的用ThinkPHP5框架快速开发出一个商业项目。

    PHP入门视频教程之一周学会PHP

    所有计算机语言的学习都要从基础开始,《PHP入门视频教程之一周学会PHP》不仅是PHP的基础部分更主要的是PHP语言的核心技术,是学习PHP必须掌握的内容,任何PHP项目的实现都离不开这部分的内容,通...

    作者信息

    kevin

    永远在学习的路上!

    相关教程

  • javascript初级视频教程 javascript初级视频教程
  • jquery 基础视频教程 jquery 基础视频教程
  • javascript三级联动视频教程 javascript三级联动视频教程
  • 独孤九贱(3)_JavaScript视频教程 独孤九贱(3)_JavaScript视频教程
  • 独孤九贱(6)_jQuery视频教程 独孤九贱(6)_jQuery视频教程
  • 热门教程