龙空技术网

5分钟掌握CSS高级使用技巧,助你薪酬翻倍!

行家网校 124

前言:

如今咱们对“css叶子”大致比较珍视,你们都需要了解一些“css叶子”的相关文章。那么小编同时在网上汇集了一些有关“css叶子””的相关文章,希望朋友们能喜欢,同学们一起来了解一下吧!

5分钟系列又和大家见面了!!大家都知道,CSS中的级联(cascade)通常能工作得非常好,但有问题的时候,也能让人很无奈,今天行家为大家整理了CSS小技巧

帮助大家解决更多烦恼,掌握这些技巧,让页面更加炫酷,工作效率更高,薪酬嘛也可以水涨船高哦~~

技巧一 :在树枝上写样式,而不该在树叶上写样式

每当你写CSS时,你想尽可能地回到树形顶部。换句话说,就是回到:root。

例如,我们的网站有一个侧边栏,希望在这个侧边栏上添加一个简短的个人介绍。其HTML的结构看起来可能会像这样:

CSS是这样写的:

这样写是能正常工作的,并不存在样式上的问题。但是,侧边栏还有一个导航nav,很有可能他们有一些样式是相同的。在我们这个示例中font-size和color都是相同的。让我们把这些属性从nav和.Bio中提取出来,并且将它们添加到其父元素.SideBar中:

事实证明,在.Posts中已经设置了line-height:1.5;。似乎整个页面都使用了相同的行高,那么我们可以将.Bio和.Posts中的line-height移到根元素中:

这看起来是一个CSS常识,但他也不会太关注兄弟元素定义同样的事情。这也让你发现,有一些代码产生重复。其实这并不可怕,因为我们只需要花点时间重新重构代码,但这样保持了CSS的代码处理健康状态。

技巧二 :样式总是作为特定属性组合出现

一个很好的例子就是color和bakground-color的组合。除非你只做小调整,不然你需要一起调整他们。

当给一个元素添加背景颜色时,它可能不包含任何文本,但可能会有一些子元素。因此,我们一起设置前景色(color)和背景色(background-color),我们总是可以确定这些元素不会遇到任何易读性和对比问题。

下次我们改变背景色时,不需要到处寻找需要修改的文本颜色,因为他们都以一个组合的形式出现在一起。

技巧三 :使用动态值,比如currentColor和em等

有时候文本颜色也会使用在其他属性上。比如说border、box-shadow或者SVG图标中的fill上。定义相同颜色有一个替代方案,可以直接使用currentColor。默认情况下,color是可以继承的,你只需要在一个地方修改就可以改变其他属性的颜色。

同样的,给font-size属性使用em单位,允许你只修改:root的font-size,就可以改变元素的盒模型大小。

技巧四 :使用inherit属性值

继承其父元素样式来覆盖UA自带样式

像button、input这样的表单控件,不同的浏览器都会有自己的样式风格(UA样式)。我们可以使用inherit继承其父元素样式,从而覆盖浏览器的UA样式。

上面示例代码取自sanitize.css, normalize.css也是这样使用的。

当然,你也可以尝试在input[type="range"]、input[type="radio"]和input[type="checkbox"]等元素上直接使用前面介绍的currentColor属性自动匹配颜色。或许你不需要改变什么,可以将一个亮色系变成一个暗色系。

· · · · · ·

以上这些小技巧,简单实用,能让你的Web站点能获取最大的好处。赶紧收藏吧!

想学习 上行家

标签: #css叶子 #css重构