我的编程空间,编程开发者的网络收藏夹
学习永远不晚

CSS的细节都有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

CSS的细节都有哪些

这期内容当中小编将会给大家带来有关CSS的细节都有哪些,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

如果说这些特性是CSS华丽的一面,那我们来看看它朴实的一面:很不起眼的东西,如选择器、单位、函数(方法)。我经常说这是繁琐的东西,但我意思是它们能干漂亮的活,这就是我要分享的。

怎么说呢,让我们看看这些效果的CSS细节;这些细节远远没有那些酷炫的CSS效果那么引人注目。它们有些已经存在一段时间了,但值得我们更好地认识,而有些则刚刚面世。虽然不起眼,但是它们可以提高我们的工作效率。

相对单位

聪明又有前瞻头脑的开发者们已经使用相对单位了——如em或者百分比——所以,开发者们了解这个问题:往往因为元素的继承性而需要使用计算器作为辅助工具来计算大小。例如,现在普遍的做法是给页面的字体设置全局尺寸,然后用相对单位来定义页面中其它的元素。CSS大概会这样写:

html { font-size: 10px; }

这样写是没问题,直到有个子元素需要设置一个不同的字体大小,比如,在这样的标签当中:

The cat sat on the <span>mat</span>.

如果你要设置span的字体大小为1.2em,你需要做什么?拿出计算器,算算1.2除以1.4是多少,结果如下:

p span { font-size: 0.85714em; }

这个问题不局限于em。如果用百分比来创建响应式的流式布局网站,而百分比是与容器相关的,所以,如果要定义一个元素为它的容器的40%,它的高是75%,宽则需要设置为53.33333%。很明显,这很不方便。

根相关的长度单位

为了修复字体大小定义的问题,现在可以使用单位rem(root em)。rem同样是相对单位,但是它所对应的是固定的基本值,这个固定的基本值也就是文档的根元素的字体大小(在HTML文件中,就是html元素)。假设和上个例子一样,同样设定10px的字体大小为根元素的大小,那么CSS这样写就OK了:

p { font-size: 1.4rem; }

这两个CSS规则都是相对于根元素的字体大小,这样的代码更加优雅和简便,特别是在设置简单的数值如10px或者12px的时候。这样和使用px值很相似,不同点在于rem是可扩展的。

在整篇文章介绍的特性中,rem特性相对来说是兼容性比较好,高级浏览器都能支持,包括IE9在内,除了Opera Mobile。

窗口相关的长度单位

觉得rem单位很酷吧,如果还有另外一组单位能解决百分比的问题,那就更酷了。它和rem的道理相似,不同点在于,它相对的不是文档的根元素,而是相对于设备窗口本身的大小。

这两个单位就是vh和vw,即是相对于窗口大小的高和宽。每个单位在前面加上数字,代表的是多少个百分比。

div { height: 50vh; }

在上面的例子,高度被设定为窗口高度的一半。1vh相当于一个百分比的窗口高度,所以50vh即是50%的窗口高度。

如果窗口大小变了,那么这个值也随之改变。这相对百分比来说,好处是不需要担心父容器,不管它的父容器如何,10vw的元素会一直是10%的窗口大小。

相应地,有vmin单位,相当于vh或者vw的最小值,最近还宣布有vmax单位会被加到规范文档里面(虽然在这篇文章发布的时候还没有)。

现在支持这个特性的有IE9+、Chrome和Safari 6。

运算式的值

如果你在做响应式的流式布局网站,经常会遇到混合单位的问题&mdash;&mdash;用百分比设置栅格,但是又用固定像素宽度设置margin。如:

div {

如果布局只用到padding和border,你可以使用box-sizing来解决,但是对于margin就无能为力了。更好、更灵活的方法是使用calc()函数,设置不同单位之间的数学方程式,如:

div {

它不仅可以用来计算宽,还可以用来计算长度&mdash;&mdash;如果有必要,还可以在calc()里面再加calc()。

这个特性IE9+和Firefox都支持,Firefox需要加上 -moz- 前缀(在版本16或17可能不用加前缀),Chrome和Safari也支持,但需要加上 -webkit- 前缀。然而,移动Webkit还不支持。

加载字体库的部分字体

优越的性能往往很重要,尤其是市场上各种各样的移动设备&mdash;&mdash;导致连接速度的差异和不确定性&mdash;&mdash;更加体现了这个重要性。其中一个加快页面加载速度的方法,就是减少外部文件个数,@font-face的一个新属性unicode-range就是为此而生。

这个属性就是unicode-range(编码范围),代表的是编码字体的参数范围。在加载外部文件的时候,只有那些被使用的字体才会被加载,而不是整套字体库。下面的代码演示了如何从foo.ttf字体库中仅加载三个字体:

@font-face {

这点对于使用字体图标的页面尤其有用。我测试过,使用unicode-range,加载字体文件的时间平均减少了0.85秒,也不是小数目了。当然,你可能不会这么想。

这个属性,目前可以在IE9+、Webkit浏览器(如Chrome和Safari)中运行。

新的伪类

单位和值都应该好好利用,但是,让我更兴奋的是选择器和伪类。完善的选择器模式,即使只有少数浏览器支持,都让我兴奋不已。引用乔布斯的话:你要把栅栏的里面修得和外面一样漂亮,即使别人看不到里面&mdash;&mdash;因为你自己知道。

我***次使用:nth-of-type()的时候,简直是一次突破,就像我冲出了思想的桎梏。好吧,我有些夸张了。但有些新的CSS伪类,确实值得狂热一番。

否定伪类

你大概不知道:not() 伪类的好,除非你亲自实践一番。带有参数的:not() 其实就是普通的选择器&mdash;&mdash;不是复合选择器。一组元素加上选择器 :not(),表示满足这个参数的元素会被排除出去。听起来有些复杂吧?但是实际上非常简单。

假设:要对项目列表的奇数行进行选择,但是***一行除外。如果是以前,需要这样写:

li { color: #00F; }

现在,通过设定:last-child作为否定伪类的参数,就可以把***一个元素排除,这样少了一行代码,从而更加的简洁和易维护。

li { color: #00F; }

否定伪类看起来并没有什么惊人之处,你可以不用它,但是它还是挺实用的。我曾经把它用在基于Webkit的项目当中,优势还是挺明显的。说实话,它是我最喜欢的伪类之一。

是的,我有最喜欢的伪类。

在本文提到的特性当中,否定伪类是兼容性***的,它被IE9+和高级浏览器支持(不需要加浏览器产商前缀)。如果你熟悉jQuery,你可能习惯用它&mdash;&mdash;版本1.0开始就有了,以及相似的not()方法。

“适用于”伪类

:matches()伪类可以用普通的选择器、复合选择器、逗号隔开的列表或任何的选择器组合作为参数。太棒了!但是,它能做什么?

:matches()伪类***大的地方就是聚合多行选择器。例如,要选择父容器里面其中几个不同子容器里面的p元素,在这之前,代码或许会写成这样:

.home header p,

有了:matches()伪类,就可以把共同点提取出来,缩减代码量。该例子里面,选择器的共同点是以home为起点、以p为终点,所以可以用:matches()把中间的所有元素集合起来。是不是有些困惑?看看代码就明白了:

.home :matches(header,footer,aside) p { color: #F00; }

这其实是CSS4的一部分(确切地说,是CSS选择器第四等级),这份规范文档还提到将会有类似的语法(以逗号隔开的复合选择器)应用于:not()伪类。兴奋ing!

目前,:matches()可以在Chrome和Safari浏览器中运行,但是要加上前缀-webkit-,Firefox也支持,但是要按照旧的写法:any(),同时要加上-moz-前缀。

上述就是小编为大家分享的CSS的细节都有哪些了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

CSS的细节都有哪些

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

WEB测试的细节有哪些

这篇文章主要介绍“WEB测试的细节有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“WEB测试的细节有哪些”文章能帮助大家解决问题。什么是Web测试?“Web 测试”也称为声明性Web 测试,它由
2023-06-04

C#中数组的细节有哪些

这篇文章主要讲解了“C#中数组的细节有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C#中数组的细节有哪些”吧!C# 数组细节在 C# 中,数组是非常重要的,且需要了解更多的细节。下面列
2023-06-17

单例模式的细节有哪些

这篇文章主要介绍“单例模式的细节有哪些”,在日常操作中,相信很多人在单例模式的细节有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”单例模式的细节有哪些”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!从去
2023-06-15

使用Python小细节有哪些

本篇内容介绍了“使用Python小细节有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!01、只要一行代码的列表生成器假如每次你想要生成个
2023-06-17

Java的性能优化细节有哪些

今天小编给大家分享一下Java的性能优化细节有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1. 尽量在合适的场合使用单
2023-06-04

Python的py文件中有哪些细节

本篇内容介绍了“Python的py文件中有哪些细节”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!模块是一种以.py为后缀的文件,我们可以在.
2023-06-02

DEDECMS网站优化的细节有哪些

本篇内容介绍了“DEDECMS网站优化的细节有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!第一、栏目url标准化当我用dede建了分类
2023-06-12

Java性能优化的细节有哪些

这篇文章主要介绍“Java性能优化的细节有哪些”,在日常操作中,相信很多人在Java性能优化的细节有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java性能优化的细节有哪些”的疑惑有所帮助!接下来,请跟
2023-06-16

final关键字的小细节有哪些

本篇内容主要讲解“final关键字的小细节有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“final关键字的小细节有哪些”吧!正文final关键字是一个常用的关键字,可以修饰变量、方法、类,
2023-06-15

Spring Cloud Stream的使用细节有哪些

Spring Cloud Stream的使用细节有哪些,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。上我们就来看看Spring Cloud Stream的一些使用细节。自定义消
2023-06-19

Java代码优化细节有哪些

本篇内容介绍了“Java代码优化细节有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、尽量指定类、方法的final修饰符带有final
2023-06-16

企业管理的流程细节有哪些

企业管理的流程细节,一般可以包括:一、流程调研;二、流程梳理;三、流程分析;四、流程设计;五、流程实施;六、流程监控;七、流程改进。流程调研是对企业现有的业务流程进行系统的、全面的调研,分析现有流程存在的问题,确定流程优化后要达到的目标。
企业管理的流程细节有哪些
2023-10-29

Java常见的误区与细节有哪些

这篇文章主要讲解了“Java常见的误区与细节有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java常见的误区与细节有哪些”吧!1.在Java中,没有goto语句。因为大量使用goto语
2023-06-17

编程热搜

目录