摘要:原文传送门一介绍为了区分伪类和伪元素,伪元素采用双冒号写法。默认情况下,伪类元素的是默认值,可以通过设置来改变其显示。举例百度前面给出一张图片,后面给出属性。复制代码百度复制代码效果调用计数器,可以不使用列表元素实现序号功能。
原文传送门: https://www.cnblogs.com/staro...
一、介绍css3为了区分伪类和伪元素,伪元素采用双冒号写法。
常见伪类——:hover,:link,:active,:target,:not(),:focus。
常见伪元素——::first-letter,::first-line,::before,::after,::selection。
::before和::after下特有的content,用于在css渲染中向元素逻辑上的头部或尾部添加内容。
这些添加不会出现在DOM中,不会改变文档内容,不可复制,仅仅是在css渲染层加入。
所以不要用:before或:after展示有实际意义的内容,尽量使用它们显示修饰性内容,例如图标。
举例:网站有些联系电话,希望在它们前加一个icon☎,就可以使用:before伪元素,如下:
复制代码
.phoneNumber::before { content:"260E"; font-size: 15px;
}
12345645654
Note:这些特殊字符的html,js和css的写法是不同的,具体可查看html特殊字符的html,js,css写法汇总。
二、content属性::before和::after必须配合content属性来使用,content用来定义插入的内容,content必须有值,至少是空。默认情况下,伪类元素的display是默认值inline,可以通过设置display:block来改变其显示。
content可取以下值。
1、string
使用引号包一段字符串,将会向元素内容中添加字符串。如:a:after{content:""}
举例:
复制代码
平凡的世界
2、attr()
通过attr()调用当前元素的属性,比如将图片alt提示文字或者链接的href地址显示出来。
starof
3、url()/uri()
用于引用媒体文件。
举例:“百度”前面给出一张图片,后面给出href属性。
复制代码
4、counter()
调用计数器,可以不使用列表元素实现序号功能。
配合counter-increment和counter-reset属性使用:
h2:before { counter-increment: chapter; content: "Chapter " counter(chapter) ". " }
代码:
复制代码
复制代码
效果:
了解更多可参考:https://developer.mozilla.org...
三、使用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-...
3、做出各种图形效果
举例:一个六角星
复制代码
width: 0;
height: 0;
border-left: 50px solid transparent;
border-right: 50px solid transparent;
border-bottom: 100px solid red;
position: relative;
}
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;
}
点我查看更多。
4、不使用图片创建小图标
举例:比如一个电话
很巧妙的应用一个div左border加圆角当机身,::before和::after配合圆角当听筒。
复制代码
#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; }
更多图标:
View Code
这个效果来自:http://www.w3cfuns.com/blog-5...
有大神用伪元素创建了84种小图标,具体可查看http://nicolasgallagher.com/p...
5、显示打印网页的URL
复制代码
6、给blockquote添加引号
经常用到给blockquote 引用段添加巨大的引号作为背景,可以用 ::before 来代替 background 。好处是即可以给背景留下空间,还可以直接使用文字而非图片:
复制代码
blockquote::before { content: open-quote; color: #ffffd; z-index: -1; font-size:80px;
}
引用一个段落,双引号用::before伪元素实现
7、超链接特效
举例:配合 CSS定位实现一个鼠标移上去,超链接出现方括号的效果
复制代码
鼠标移上去出现方括号
复制代码
更多创意链接特效可参考: Creative Link Effects 。
8、::before和::after实现多背景图片
举例:一个标签应用5张背景图
View Code
原效果来自:Multiple Backgrounds and Borders with CSS 2.1
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/113858.html
摘要:原文传送门一介绍为了区分伪类和伪元素,伪元素采用双冒号写法。默认情况下,伪类元素的是默认值,可以通过设置来改变其显示。举例百度前面给出一张图片,后面给出属性。复制代码百度复制代码效果调用计数器,可以不使用列表元素实现序号功能。 原文传送门: https://www.cnblogs.com/staro... 一、介绍 css3为了区分伪类和伪元素,伪元素采用双冒号写法。 常见伪类——:h...
摘要:原文传送门一介绍为了区分伪类和伪元素,伪元素采用双冒号写法。默认情况下,伪类元素的是默认值,可以通过设置来改变其显示。举例百度前面给出一张图片,后面给出属性。复制代码百度复制代码效果调用计数器,可以不使用列表元素实现序号功能。 原文传送门: https://www.cnblogs.com/staro... 一、介绍 css3为了区分伪类和伪元素,伪元素采用双冒号写法。 常见伪类——:h...
摘要:关于的源码分析,本文并不打算展开讲了。大家可以参考我之前的一篇文章源码详细分析。在删除节点时,父类的删除逻辑并不会修复所维护的双向链表,这不是它的职责。在节分析链表建立过程时,我故意忽略了部分源码分析。 1. 概述 LinkedHashMap 继承自 HashMap,在 HashMap 基础上,通过维护一条双向链表,解决了 HashMap 不能随时保持遍历顺序和插入顺序一致的问题。除此...
摘要:介绍是一个扩展,主要用来观察内存泄露问题,基本用法如下实现分析分析的版本为。的入口函数在文件中,通过进行声明。下面分析下函数的具体实现函数内部会递归调用函数得到最终堆快照的结果。回调的触发与的钩子有关,详细看下一节分析。 介绍 memwatch是一个c++扩展,主要用来观察nodejs内存泄露问题,基本用法如下: const memwatch = require(@airbnb/mem...
摘要:,,面向切面编程。,切点,切面匹配连接点的点,一般与切点表达式相关,就是切面如何切点。例子中,注解就是切点表达式,匹配对应的连接点,通知,指在切面的某个特定的连接点上执行的动作。,织入,将作用在的过程。因为源码都是英文写的。 之前《零基础带你看Spring源码——IOC控制反转》详细讲了Spring容器的初始化和加载的原理,后面《你真的完全了解Java动态代理吗?看这篇就够了》介绍了下...
阅读 3686·2021-09-24 10:24
阅读 1340·2021-09-22 16:01
阅读 2667·2021-09-06 15:02
阅读 982·2019-08-30 13:01
阅读 977·2019-08-30 10:52
阅读 597·2019-08-29 16:36
阅读 2199·2019-08-29 12:51
阅读 2302·2019-08-28 18:29