分享好友 前端技术首页 频道列表

CSS中关于变量的基本教程

css教程  2015-08-09 20:220

CSS中的变量给了我们诸多优点:方便、代码重用、更可靠的代码库和提升防错能力。
示例

CSS Code复制内容到剪贴板
  1. :root {   
  2.   --base-font-size16px;   
  3.   --link-color#6495ed;   
  4. }   
  5. p {   
  6.   font-size: var( --base-font-size );   
  7. }   
  8. a {   
  9.   font-size: var( --base-font-size );   
  10.   color: var( --link-color );   
  11. }  

基础

当使用CSS变量时,你应该了解的三个主要组成:

    自定义属性
    var()函数
    :root伪类

自定义属性

你已经知道了一些CSS的标准属性,如color,margin,width和font-size。
下面的示例使用了CSS的color属性:

CSS Code复制内容到剪贴板
  1. body {   
  2.   color#000000/* The "color" CSS property */  
  3. }  

自定义属性仅意味着我们(创建CSS文件的人)去定义属性的名字。
为了自定义一个属性名,我们需要用--作为前缀。
如果我们要创建一个值为黑色的、名为text-color的自定义属性,可以这样做:

CSS Code复制内容到剪贴板
  1. :root {   
  2.   --text-color#000000/* A custom property named "text-color" */  
  3. }  

var()函数

为了应用自定义属性,需要利用var()函数,否则浏览器不知道他们代表什么。
如果想要在p、h1和h2中的样式中使用--text-color,可以这样使用var()函数:

CSS Code复制内容到剪贴板
  1. :root {   
  2.   --text-color#000000;   
  3. }   
  4. p {   
  5.   color: var( --text-color );   
  6.   font-size16px;   
  7. }   
  8. h1 {   
  9.   color: var( --text-color );   
  10.   font-size42px;   
  11. }   
  12. h2 {   
  13.   color: var( --text-color );   
  14.   font-size36px;   
  15. }  

其等价于:

CSS Code复制内容到剪贴板
  1. p {   
  2.   color#000000;   
  3.   font-size16px;   
  4. }   
  5. h1 {   
  6.   color#000000;   
  7.   font-size42px;   
  8. }   
  9. h2 {   
  10.   color#000000;   
  11.   font-size36px;   
  12. }  

:root伪类

我们需要一个地方来放置自定义属性。虽然可以在任何样式规则中指定自定义属性,但到处定义属性并不是一个好主意,这对CSS的可维护性和可阅读性是一个挑战。

:root 伪类代表了HTML文档的根元素,这是一个放置自定义属性的好位置,因为我们可以通过其他更具特异性的选择器来覆盖自定义属性值。
CSS变量的好处
可维护性

在一个Web开发项目中,我们经常重复使用一个特定的CSS属性值:

CSS Code复制内容到剪贴板
  1. h1 {   
  2.   margin-bottom20px;   
  3.   font-size42px;   
  4.   line-height: 120%;   
  5.   colorgray;   
  6. }   
  7. p {   
  8.   margin-bottom20px;   
  9.   font-size18px;   
  10.   line-height: 120%;   
  11.   colorgray;   
  12. }   
  13. img {   
  14.   margin-bottom20px;   
  15.   border1px solid gray;   
  16. }   
  17. .callout {   
  18.   margin-bottom20px;   
  19.   border3px solid gray;   
  20.   border-radius: 5px;   
  21. }  

当需要改变某些属性值时,问题就会暴露出来了。
如果我们手动的改变属性值,尤其是当CSS文件很大时,不仅会花费大量时间,还可能会范一些错误。同样的,如果我们执行一个批处理查找和替换,就可能会无意中影响其他样式规则。
我们可以使用CSS变量重写:

CSS Code复制内容到剪贴板
  1. :root {   
  2.   --base-bottombottom-margin20px;   
  3.   --base-line-height:   120%;   
  4.   --text-color:         gray;   
  5. }   
  6. h1 {   
  7.   margin-bottom: var( --base-bottombottom-margin );   
  8.   font-size42px;   
  9.   line-height: var( --base-line-height );   
  10.   color: var( --text-color );   
  11. }   
  12. p {   
  13.   margin-bottom: var( --base-bottombottom-margin );   
  14.   font-size18px;   
  15.   line-height: var( --base-line-height );   
  16.   color: var( --text-color );   
  17. }   
  18. img {   
  19.   margin-bottom: var( --base-bottombottom-margin );   
  20.   border1px solid gray;   
  21. }   
  22. .callout {   
  23.   margin-bottom: var( --base-bottombottom-margin );   
  24.   border1px solid gray;   
  25.   border-radius: 5px;   
  26.   color: var( --text-color );   
  27. }  

假设你现在的客户说由于文本颜色太亮,导致文本难以阅读,想要改变文本颜色,此时,我们只需要更新一行CSS规则:

CSS Code复制内容到剪贴板
  1. --text-colorblack;  

提高CSS的可读性

自定义属性会使样式表更加易读,也会使CSS属性声明更有语义。
将这个声明

CSS Code复制内容到剪贴板
  1. background-coloryellow;  

和下面的声明比较一下

CSS Code复制内容到剪贴板
  1. background-color: var( --highlight-color );   
  2. font-size: var( --base-font-size );  

像yellow和18px一类的属性值并没有给我们任何有用的上下文信息,但是当我们阅读如--base-font-size和--highlight-color一样的属性名时,即便在其他人的代码,我们都能马上知道这个属性值是在做什么。
要注意的事
大小写敏感

自定义属性是大小写敏感的(和普通的CSS规则不一样)

CSS Code复制内容到剪贴板
  1. :root {   
  2.   --main-bg-colorgreen;   
  3.   --MAIN-BG-COLOR: RED;   
  4. }   
  5. .box {   
  6.   background-color: var( --main-bg-color ); /* green background */  
  7. }   
  8. .circle {   
  9.   BACKGROUND-COLOR: VAR(--MAIN-BG-COLOR ); /* red background */  
  10.   border-radius: 9999em;   
  11. }   
  12. .box,   
  13. .circle {   
  14.   height100px;   
  15.   width100px;   
  16.   margin-top25px;   
  17.   box-sizing: padding-box;   
  18.   padding-top40px;   
  19.   text-aligncenter;   
  20. }  

自定义属性值的解析

当重复声明自定义属性时,其赋值遵循通常的CSS层叠和继承规则。例如下面的示例:
HTML

XML/HTML Code复制内容到剪贴板
  1. <body>  
  2.   <div class="container">  
  3.     <a href="">Link</a>  
  4.   </div>  
  5. </body>  

CSS

CSS Code复制内容到剪贴板
  1. :root {   
  2.   --highlight-coloryellow;   
  3. }   
  4. body {   
  5.   --highlight-colorgreen;   
  6. }   
  7. .container {   
  8.   --highlight-colorred;   
  9. }   
  10. a {   
  11.   color: var( --highlight-color );   
  12. }  

当移除.container规则时,链接的颜色值将是green。
回退值

当使用var()函数时,可以分配一个回退的属性值,其作为一个额外参数和第一个参数用,隔开。看下面的示例:
HTML

XML/HTML Code复制内容到剪贴板
  1. <div class="box">A Box</div>  

CSS

CSS Code复制内容到剪贴板
  1. div {   
  2.   --container-bg-colorblack;   
  3. }   
  4. .box {   
  5.   width100px;   
  6.   height100px;   
  7.   padding-top40px;   
  8.   box-sizing: padding-box;   
  9.   background-color: var( --container-bf-colorred );   
  10.   colorwhite;   
  11.   text-aligncenter;   
  12. }  

因为给var()传递了一个回退值参数,所以div的背景色最中被渲染成红色。
无效值

谨防给CSS属性分配错误类型的值。
在下面的示例中,由于自定义属性--small-button被赋予一个长度单位,它被用在.small-button样式中是无效的(译者注:因为color的属性类型值出错)

CSS Code复制内容到剪贴板
  1. :root {   
  2.   --small-button: 200px;   
  3. }   
  4. .small-button {   
  5.  color: var(--small-button);   
  6. }  

避免这种情况的一个好方式是想出具有描述性的自定义属性名称。例如将上面的自定义属性命名为--small-button-width
浏览器对CSS变量的支持

CSS变量用起来很方便,但是浏览器对其支持情况不太好:
CSS中关于变量的基本教程

查看更多关于【css教程】的文章

展开全文
相关推荐
反对 0
举报 0
评论 0
图文资讯
热门推荐
优选好物
更多热点专题
更多推荐文章
Bootstrap.css 中请求googleapis.com/css?family 备忘录
问题描述: Web中引入bootstrap.css中头部有访问Google服务器的请求 @import url("//fonts.googleapis.com/css?family=Open+Sans:400italic,700italic,400,700");     国内访问不稳定,页面反应慢解决:将请求结果保存下来,放到本地,重新声明请求1.请求http:

0评论2023-03-16312

Vue PostCSS的使用介绍
目录PostCSS使用安装依赖运行使用第三方插件autoprefixer使用第三方插件postcss-preset-env使用第三方插件postcss-pxtorem运行的新方式PostCSSpostcss 一种对css编译的工具,类似babel对js的处理,常见的功能如:1 . 使用下一代css语法2 . 自动补全浏览器前缀

0评论2023-03-08315

css实现弹出框 css弹出菜单
弹出框也是前端里面经常使用的一个应用场景了,最开始想到的是用js实现这个效果,看到codepen上面有用css实现的。其实就是用到了css里面的一个:target选择器+visibility属性。URL 带有后面跟有锚名称 #,指向文档内某个具体的元素。这个被链接的元素就是目标

0评论2023-03-08519

jfinal框架页面找不到相关css,js文件404
在JFinalConfig中添加配置: @Overridepublic void configHandler(Handlers handlers) {handlers.add(new ContextPathHandler());}页面中添加:base href="${CONTEXT_PATH}/"/之前页面找不到资源,把tomcat工程路径去掉了(path=""),这样暂时解决了问题推荐

0评论2023-03-08576

移动端CSS底部固定和fixed定位在ios上的bug
fixed定位在ios上的bugcss三栏布局假设我们页面的 HTML 结构是这样: div class="wrapper"div class="content"!-- 页面主体内容区域 --/divdiv class="footer"!-- 需要做到 Sticky Footer 效果的页脚 --/div/div方法1.:absolute通过绝对定位处理应该是常见的

0评论2023-03-08624

css实现图片翻转 css使图片旋转
!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"html xmlns="http://www.w3.org/1999/xhtml"headmeta http-equiv="Content-Type" content="text/h

0评论2023-03-08577

CSS3中的px,em,rem,vh,vw辨析 css3 vw
1、px:像素,精确显示2、em:继承父类字体的大小,相当于“倍”,如:浏览器默认字体大小为16px=1em,始终按照div继承来的字体大小显示,进场用于移动端          em换算工具:http://www.runoob.com/tags/ref-pxtoemconversion.html3、rem:与em类似,

0评论2023-03-08902

gulp自动化构建工具--自动编译less为css--学习笔记
 1.安装      命令:npm install gulp-less 或者 cnpm install gulp-less2.编写文件 //获取gulpvar gulp = require('gulp')//获取gulp-less模块var less = require("gulp-less")//编译less//在命令行输入gulp less启动此任务gulp.task('less',function(){

0评论2023-03-08411

关于动画Animate.css的使用方法
    首先贴个官网:https://daneden.github.io/animate.css/  1、引入animate css文件 1 head2 link rel="stylesheet" href="animate.min.css"3 /head   2、给指定的元素加上指定的动画样式名div class="animated bounceOutLeft"/div    这里包

0评论2023-03-08673

selenium Firefox禁用js,css.falsh,缓存,设置请求头和代理ip
1 profile = FirefoxProfile() 2 #请求头 3 #profile.set_preference("general.useragent.override", util.http_agent_insert(xinhuaUtil.agent_path)) 4 # 激活手动代理配置(对应着在 profile(配置文件)中设置首选项) 5 profile.set_preference("network

0评论2023-03-08777

CSS--容易混淆的.class1.class2与.class1 .class2的区别
容易混淆的.class1.class2与.class1 .class2的区别:第一个中间没空格的,匹配的是同时拥有class1和class2的元素。第二个中间有空格的,匹配的是父节点是class1类,子节点是class2类的元素。

0评论2023-03-08554

页面css样式找不到问题 页面css样式找不到问题怎么解决
出现了一个页面没有样式的问题:问题:  1.路径不对, 可以打开页面f12看样式是否找到  检查路径是否正确。  2.样式没引全或者没引对。查看引入的样式是否正确或缺少样式。  3.路径明明写对了却404找不到。可以试一试把${pageContext.request.context

0评论2023-03-08414

学习前端页面css定位 网页前端设计css
一、相对定位:absolute  相对定位是一个非常容易掌握的概念。如果对一个元素进行相对定位,它将出现在它所在的位置上。然后,可以通过设置垂直或水平位置,让这个元素“相对于”它的起点进行移动。position:relative;同时可以设置上下左右位置偏移;rela

0评论2023-03-08782

css-移动端模拟hover效果 css移动端适配
:hover 在移动端中,点击后一直处于hover状态,不会切换。为此解决:通过:active模拟!-- * @Author: lingxie * @Date: 2020-04-23 13:35:57 * @Descripttion: -- templatediv class="about"h1This is an about page/h1div class="btn-hole"按钮/div/div/templ

0评论2023-03-08409

更多推荐