



全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
未来的CSS太让人兴奋了:一方面,是全新的页面布局方式;另一方面,是酷炫的滤镜、颜色等视觉效果。这些CSS,受开发者追捧,被杂志和博客文章铺天盖地地介绍。如果说这些特性是CSS华丽的一面,那我们来看看它朴实的一面:很不起眼的东西,如选择器、单位、函数(方法)。我经常说这是繁琐的东西,但我意思是它们能干漂亮的活,这就是我要分享的。怎么说呢,让我们看看这些效果最好的朴实的CSS细节这些细节远远没有那些酷炫的CSS效果那么引人注目。它们有些已经存在一段时间了,但值得我们更好地认识,而有些则刚刚面世。虽然不起眼,但是它们可以提高我们的工作效率以谦虚的姿态。相对单位聪明又有前瞻头脑的开发者们已经使用相对单位了如em或者百分比所以,开发者们了解这个问题:往往因为元素的继承性而需要使用计算器作为辅助工具来计算大小。例如,现在普遍的做法是给页面的字体设置全局尺寸,然后用相对单位来定义页面中其它的元素。CSS大概会这样写:html font-size: 10px; p font-size: 1.4em; 这样写是没问题,直到有个子元素需要设置一个不同的字体大小,比如,在这样的标签当中:The cat sat on the mat.如果你要设置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; p span font-size: 1.2rem; 这两个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。运算式的值如果你在做响应式的流式布局网站,经常会遇到混合单位的问题用百分比设置栅格,但是又用固定像素宽度设置margin。如:div margin: 0 20px; width: 33%;如果布局只用到padding和border,你可以使用box-sizing来解决,但是对于margin就无能为力了。更好、更灵活的方法是使用calc()函数,设置不同单位之间的数学方程式,如:div margin: 0 20px; width: calc(33% - 40px);它不仅可以用来计算宽,还可以用来计算长度如果有必要,还可以在calc()里面再加calc()。这个特性IE9+和Firefox都支持,Firefox需要加上 -moz- 前缀(在版本16或17可能不用加前缀),Chrome和Safari也支持,但需要加上 -webkit- 前缀。然而,移动Webkit还不支持。加载字体库的部分字体优越的性能往往很重要,尤其是市场上各种各样的移动设备导致连接速度的差异和不确定性更加体现了这个重要性。其中一个加快页面加载速度的方法,就是减少外部文件个数,font-face的一个新属性unicode-range就是为此而生。这个属性就是unicode-range(编码范围),代表的是编码字体的参数范围。在加载外部文件的时候,只有那些被使用的字体才会被加载,而不是整套字体库。下面的代码演示了如何从foo.ttf字体库中仅加载三个字体:font-face font-family: foo;src: url(foo.ttf);unicode-range: U+31-33;这点对于使用字体图标的页面尤其有用。我测试过,使用unicode-range,加载字体文件的时间平均减少了0.85秒,也不是小数目了。当然,你可能不会这么想。这个属性,目前可以在IE9+、Webkit浏览器(如Chrome和Safari)中运行。新的伪类单位和值都应该好好利用,但是,让我更兴奋的是选择器和伪类。完善的选择器模式,即使只有少数浏览器支持,都让我兴奋不已。引用乔布斯的话:你要把栅栏的里面修得和外面一样漂亮,即使别人看不到里面因为你自己知道。我第一次使用:nth-of-type()的时候,简直是一次突破,就像我冲出了思想的桎梏。好吧,我有些夸张了。但有些新的CSS伪类,确实值得狂热一番。否定伪类你大概不知道 :not()伪类的好,除非你亲自实践一番。带有参数的 :not()其实就是普通的选择器不是复合选择器。一组元素加上选择器:not(),表示满足这个参数的元素会被排除出去。听起来有些复杂吧?但是实际上非常简单。假设:要对项目列表的奇数行进行选择,但是最后一行除外。如果是以前,需要这样写:li color: #00F; li:nth-child(odd) color: #F00; li:last-child color: #00F; 现在,通过设定:last-child作为否定伪类的参数,就可以把最后一个元素排除,这样少了一行代码,从而更加的简洁和易维护。li color: #00F; li:nth-child(odd):not(:last-child) color: #F00; 否定伪类看起来并没有什么惊人之处,你可以不用它,但是它还是挺实用的。我曾经把它用在基于Webkit的项目当中,优势还是挺明显的。说实话,它是我最喜欢的伪类之一。是的,我有最喜欢的伪类。在本文提到的特性当中,否定伪类是兼容性最好的,它被IE9+和高级浏览器支持(不需要加浏览器产商前缀)。如果你熟悉jQuery,你可能习惯用它版本1.0开始就有了,以及相似的not()方法。“适用于”伪类:matches() 伪类可以用普通的选择器、复合选择器、逗号隔开的列表或任何的选择器组合作为参数。太棒了!但是,它能做什么?:matches() 伪类最强大的地方就是聚合多行选择器。例如,要选择父容器里面其中几个不同子容器里面的p元素,在这之前,代码或许会写成这样:.home header p,.home footer p,.home aside p color: #F00;有了:matches()伪类,就可以把共同点提取出来,缩减代码量。该例子里面,选择器的共同点是以home为起点、以p为终点,所以可以用:matches()把中间的所有元素集合起来。是不是有些困惑?看看代码就明白了:.home :matches(header,footer,aside) p color: #F00; 这其实是CSS4的一部分(确切地说,是CSS选择器第四等级),这份规范文档还提到将会有类似的语法(以逗号隔开的复合选择器)应用于:not()伪类。兴奋ing!目前,:matches()可以在Chrome和Safari浏览器中运行,但是要加上前缀-webkit-,Firefox也支持,但是要按照旧的写法:any
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025房地产开发代理合同(含景观设计)
- 2025常州二手房过户税费筹划与税务筹划合同
- 海南省儋州市2025年上半年事业单位公开遴选试题含答案分析
- 海南省澄迈县2025年上半年公开招聘村务工作者试题含答案分析
- 2025版现代服务业用地抵押担保合作协议
- 2025版实验动物中心动物实验动物饲养合同
- 贵州省织金县2025年上半年公开招聘村务工作者试题含答案分析
- 贵州省荔波县2025年上半年公开招聘村务工作者试题含答案分析
- 2025版企业员工培训与进修资助服务合同
- 2025版原材料进出口采购代理合同
- crh5a型动车组四级检修修订改
- 纯净水生产项目可行性分析报告
- 监理内业资料整理要点
- GB/T 21652-2017铜及铜合金线材
- GB/T 12234-2019石油、天然气工业用螺柱连接阀盖的钢制闸阀
- 全套教学课件《公共艺术(音乐)》
- 高中数学《基于问题链的数学教学探索》课件
- (卓越绩效)质量奖申报材料
- 同创伟业投资分析报告(附358家被投企业介绍)
- 数学-四年级(上册)-人教版-《亿以上数的认识及读法》教学课件
- 政治经济学ppt课件汇总(完整版)
评论
0/150
提交评论