转载自: 腾讯ISUX (https://isux.tencent.com/card-design-thinking.html)

CSS Variable 即CSS变量,聊CSS变量之前,我想先来说说Sass和Less,还有Stylus,它们都是目前使用较为普遍的三款CSS预处理框架,我们为什么要使用它们呢,因为它们都可以让你在CSS中方便的使用变量、简单的程序逻辑、函数等在编程时使用的一些基本技巧,这些框架对于这种CSS预处理的技术已经非常成熟,可以让你的CSS代码变的更加简洁、便于维护、在编写的时候也无需考虑代码的兼容性。

三大编译语言的方法

首先他们不约而同的都将自己的名称做为编译文件的后缀名,分别是:

由于Sass和Less都使用的是标准的CSS语法,和Stylus有所不同,它们分别支持以下几种语法:

它们的变量使用方法也有不太一样的地方:

以上三种框架编译后的写法,都会得到以下相同的样式:

其次就是嵌套方式,有时候我们的类名会引入非常多的父级元素,这样冗余的代码,不仅没有提升可读性,而且增加代码的体积

如果使用CSS预处理,就可以少些重复的类名,代码结构层次清晰,显得会比较优雅:

css变量的方法

那么CSS变量这边的情况又是如何?关于变量,其实不外乎定义和使用,我们可以通过这样一个简单的例子来了解,例如下图, 这里定义了三个变量,title、link、text,变量的应用范围是整个document

当然CSS变量也是有应用范围的,这就是说,你可以覆盖它们,因为变量的声明和使用遵循了CSS的层叠特性,类似于普通编程语言中的变量作用域:

这样定义后,p就变成另外一种颜色(黑色)
CSS变量还可以赋予任何值,例如,你可以把它们放到calc()计算表达式里。这样可以在不同的情况下对CSS变量重新赋值,比如,在不同的media query里赋不同的值。下面是一些使用场景的例子:

根据上面的CSS定义,当浏览器窗口小于等于640px时,media query就会发生作用,里面的CSS变量值发生变化。

CSS变量的用途

在我们构建站点的时候,通常为了站点的可维护性,例如使用换肤,或者某一种配色方案,当中的文字颜色、字体大小、背景色等等会在页面中多次出现,并被重复使用,当你需要修改的时候,不论是调整配色还是文字大小,都可以通过之前设置好的CSS变量来直接修改。

那么为什么我要使用CSS变量呢

相较于传统的Sass、Less、Stylus等预处理变量,CSS变量有它的优势:

1.CSS变量直接修改,立即生效,而传统与处理器变量编译后无法直接更改

2.CSS变量能够像CSS本身一样,能够继承,能够组合使用,可以作用需要的地方即作用域

3.配合上JS,可以方便的读写和控制

4.语法上类似CSS和JS,方便快速上手开发,不需要像其它传统预处理变量那样,需要学习各种语法,开发和交接成本低

5.CSS变量本身包换了语义的信息,在CSS文件中能够被识别和理解。

6.当多个媒介查询的时候,重复定义的代码量会成倍增加。因为CSS变量可以传递,当我们使用响应式的时候,我们只需要修改一个CSS属性值即可。下图中我们只需要修改–columns这一个变量即可。

css变量支持的情况

下面是目前浏览器支持的情况,虽然IE依旧不能够支持,但是如果是在移动端,还是可以来尝试一下的,当然如果有兴趣的可以关注一下:cssnext,myth这个两个插件,可以让我们提前使用CSS变量的一些方法:

总结

总的来说,CSS变量还是能够针对性的解决一些项目中的实际问题:

比如一个站点的配色,如果只是几个常用的颜色被应用到多个地方,我们完全可以通过CSS变量来轻松修改,并不需要用到Less、Sass、Stylus这样”复杂”的编译系统。

在响应式代码中不需要重复声明变量,在Less和Sass中也没办法做到像CSS变量那样简洁优雅的代码。

最后,写这篇文章并不是想说CSS变量要取代谁和谁,而是,我们在开发过程中,应该思考自己需要通过工具解决某个实际存存在的问题!

腾讯ISUX: 面向未来的 CSS Variable (CSS变量)相关推荐

  1. 每个前端都需要知道这些面向未来的CSS技术

    写在前面 前端技术日新月异,我们需要不断学习来更新自己的前端知识并运用到自己的项目中.这次笔者整理一些未来普及或者现在同学们可能已经用到的CSS特性,包括SVG图标.滚动特性.CSS自定义属性.CSS ...

  2. 面向未来的跨界开发技术(下)

    作者简介:余果,腾讯社交用户体验设计部高级UI工程师,前端开发组负责人,UI开发通道评委,腾讯云特邀布道师,<Web全栈工程师的自我修养>作者 在上一篇文章中,我们定义了"未来& ...

  3. Go 语言学习总结(4)—— 为什么说 Golang 是面向未来的语言?

    前言 Golang 是最年轻的编程语言之一,于 2007 年设计,由 Ken Thompson(UNIX 和 C 的设计者和创建者).Rob Pike(UTF 8 和 UNIX 格式的共同创建者)和 ...

  4. 腾讯前端组件android,前端之Android入门(2):程序目录及UI简介 - 腾讯ISUX

    在这次的文章中,将会介绍Android程序的目录结构以及UI知识,为下一篇实际例子的编写打下基础.由于文章篇幅有限,所以本着先浅后深的思路,从简单介绍入手,然后在往后实际例子编写中再深入扩展学习各个知 ...

  5. 落地零售智能体,百联集团全力打造面向未来的数字化商业体

    "十四五"期间,百联集团将通过深化数字化商业系统的建设,围绕客户价值,数字化重构商业"人.货.场". 出品 | 常言道 作者 | 丁常彦 作为商品流通的终端环节 ...

  6. 第五届世界人工智能大会 • 腾讯“智变未来”论坛召开

    9月1日,第五届世界人工智能大会 • 腾讯"智变未来"论坛在上海西岸艺术中心召开.本次论坛由上海市经济和信息化委员会.徐汇区政府和世界人工智能大会组委会办公室指导,腾讯华东总部.腾 ...

  7. 智库大会 | 面向未来 向新时代发出数字经济倡议书

    2018年1月16日,由阿里研究院和中国远见智库论潭联合主办的第三届新经济智库大会在北京召开,论坛以"新时代 新引擎 新担当"为主题,聚焦数字经济,国内外60余位专家学者就数字鸿沟 ...

  8. html5 3d场景设计,打造H5里的“3D全景漫游”秘籍 - 腾讯ISUX

    原标题:打造H5里的"3D全景漫游"秘籍 - 腾讯ISUX 近来风生水起的VR虚拟现实技术,抽空想起年初完成的"星球计划"项目,总结篇文章与各位分享一下制作基于 ...

  9. 陈凯:面向未来的多云管理平台

    2018年3月21-22日,由中国信息通信研究院主办.中国通信标准化协会支持的"OSCAR云计算开源产业大会"在国家会议中心举行. 混合云论坛作为"OSCAR云计算开源产 ...

最新文章

  1. ecplise 设置代码自动提示功能的设置
  2. K单体型重建算法的研究
  3. 【055】长江水文数据自动记录程序
  4. linux集群巡检,Linux巡检
  5. Nginx 反向代理、负载均衡、页面缓存、URL重写及读写分离详解(1)
  6. ▲为什么要用css Sprite技术?
  7. linux下elasticsearch的安装
  8. Python爬虫自学之第(②)篇——BeautifulSoup解析网页
  9. android camera2 qcom,lineage编译环境里,编译QCamera2的技术总结
  10. Ov两款骁龙865手机即将发布:其中一款或低于2999元
  11. python日期对照表_2020年日期表-python实现
  12. java web项目用cookie记住用户名、密码
  13. SPSS 随机区组秩和检验
  14. spring基础内容
  15. 获取微信运动 php,微信运动数据抓取(PHP语言)
  16. Output tensors to a Model must be the output of a TensorFlow `Layer`
  17. .find()的用法
  18. 智慧社区系统开发,智慧社区平台搭建解决方案
  19. C语言采药动态规划,动态规划_POJ1775:采药
  20. jenkins如何得到日期

热门文章

  1. 82.Hive SQL插入动态分区的异常分析
  2. Android图片打水印
  3. IT运维相关技术文档
  4. 机器人李继红_电力设备
  5. react-diagram 序列化Json解读
  6. 网页上简体繁体汉字切换
  7. How to edit registry via CMD command
  8. vtk中长度测量和角度测量
  9. vivado的使用技巧整理
  10. WordPress-微信机器人高级版