如何理解CSS的变量和继承相关知识
Admin 2022-07-14 群英技术资讯 468 次浏览
朋友,百姓网前端架构师css魔法的《css揭秘》,已经出版发行,并赠送了我一本。看了一下这本书,确实有很多css技巧。让你会有蛮大的收获,在这里帮他宣传一下!今天所说的案例呢,也是部分借鉴这本书的。今天和大家聊聊css变量和继承!
有人会说,css怎么会有变量和继承?你是说的css处理器吧!
不是,我说的是纯css,其实,css也在努力融入各种预处理器的特性和写法,甚至有些属性比预处理器更加强大,例如:
闲话少说,我们还是切入正题吧!
css变量
其实我说的变量,并非css处理器中的自定义变量,而是css某些属性有类似变量的功能!
这个属性就是currentColor
currentColor 的应用
1、镂空图片镂空和currentColor
代码如下:
.icon {
display: inline-block;
background-image: url(h/216/0y89gzo2/sprite_icons.png);
background-color: currentColor; /* 该颜色控制图标的颜色 */
}
.link:hover { color: #333; }/* 虽然改变的是文字颜色,但是图标颜色也一起变化了 */
解释: 默认图标的背景颜色currentColor用的是link的颜色,link颜色改变时,图标的背景颜色也随着改变!
2、水平分割线和文本颜色保持一致,假如你所有的hr 颜色要和文本颜色保持一致,有了currentColor,可以如下写
hr{height:.5em;background:currentColor}
假如你的文本颜色变了,hr也会自动变。
css继承
继承我们用的是inherit属性
这个应用到时蛮多的,例如设置字体,表单的字体我们要和页面其他部分相同,我们不用重复定于,只要继承其他的就可以!
input,select,button{font:inherit}
超链接颜色与其他颜色相同,可以用:
a{color:inherit}
提示对话框的小箭头,要和整体对话框一直,包括边框和背景,我们可以用inherit
关于对话框,我前面文章也有关于css书写对话框的 ,但是这种写法对于对话框的边框很难控制,看下下面的这个应用吧!
代码如下:
.callout{position:relative;background-color:#ccc;border:1px solid red;}
.callout::before{content:"";position:absolute;top:-.4em;left:1em;padding:.35em;background:inherit;
border:inherit;border-right:0;border-bottom:0;transform:rotate(45deg);}//先写一个正方形,然后旋转45度变为三角形
例子
:root { --color: blue; }
div { --color: green; }
#alert { --color: red; }
* { color: var(--color); }
I inherited blue from the root element!
I’m red too, because of inheritance!
背景和边框继承callout,这样写起来更加方便了!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
今天主要介绍一下CSS3 动画卡顿解决方案,原因就是主线程和合成线程的调度不合理。本文详解的介绍了解决方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
这篇文章主要介绍了CSS3为背景图设置遮罩并解决遮罩样式继承问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
用CSS3怎样实现一个球体效果?CSS3的功能还是很强大的,能实现很多的图形效果,这篇我们主要来看如何实现一个球体的效果,文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
css3动画用“@keyframes”来定制规则。“@keyframes”可以指定动画规则,定义CSS动画的一个周期的行为,语法“@keyframes 动画名称{keyframes-selector {css-styles;}}”。
这篇文章主要介绍transition和animation的区别,为了帮助大家了解清楚transition属性和animation属性的不同,本文对transition属性和animation属性都有很详细的介绍,感兴趣的朋友就继续往下看吧。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008