Google Closure Stylesheets 让我们更易于使用CSS

2024-02-10 01:38

本文主要是介绍Google Closure Stylesheets 让我们更易于使用CSS,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  Google 已经基于 Apache License 2.0 把 Closure Stylesheets 开源,这种工具属于 Closure Tools 包之内,在处理 CSS 的时候很有用。Closure Stylesheets 是一个 Java 程序,它向 CSS 中添加了变量、函数、条件语句以及混合类型,使得我们更易于处理大型的 CSS 文件。开发者可以使用 Google stylesheets (GSS)这种工具来生成 web 应用程序或者网站所使用的真正的 CSS 文件。

  变量

  变量是使用“@def”来定义的。下面的代码示例展示了如何使用变量:

01   @def BG_COLOR rgb (235239249);
02  
03   @def DIALOG_BG_COLOR BG_COLOR;body {
04  
05   background-color: BG_COLOR;
06  
07   }
08  
09   .dialog {
10  
11   background-color: DIALOG_BG_COLOR;
12  
13   }
14  
15 得到的 CSS 如下:
16  
17   body {
18  
19   background-color#ebeff9;
20  
21   }
22  
23   .dialog {
24  
25   background-color#ebeff9;
26  
27   }

  函数

  Closure Stylesheets 引入了大量数学函数,使用它们你可以对数字型的值——比方说像素——进行以下操作: add ()、 sub ()、mult ()、 div ()、 min ()以及max ()。使用这些函数的示例如下:

01 @def LEFT_WIDTH 100px;
02  
03 @def LEFT_PADDING 5px;
04  
05 @def RIGHT_PADDING 5px;.content {
06  
07 positionabsolute;
08  
09 margin-left: add (LEFT_PADDING,
10  
11 LEFT_WIDTH,
12  
13 RIGHT_PADDING,
14  
15 px);

  得到的 CSS 如下所示:

1 .content {
2  
3 positionabsolute;
4  
5 margin-left110px;
6  
7 }

  条件语句

  Closure Stylesheets 让我们可以使用@if、@elseif 和@else,从而基于某些变量的值来创建条件语句的分支。

  混合类型

  混合类型是为了重用带有参数的对结构体的声明,如下示例所示:

01 @defmixin size (WIDTH, HEIGHT) {
02  
03 width: WIDTH;
04  
05 height: HEIGHT;
06  
07 }
08  
09 .image {
10  
11 @mixin size (200px, 300px);
12  
13 }

  当解决跨浏览器的问题时,混合类型会更有用:

01 @defmixin gradient (POS, HSL1, HSL2, HSL3, COLOR, FALLBACK_COLOR) {
02  
03 background-color: FALLBACK_COLOR; /* fallback color if gradients are not supported */
04  
05 background-image: -webkit-linear-gradient (POS, hsl (HSL1, HSL2, HSL3), COLOR); /* Chrome 10+,Safari 5.1+ */
06  
07 /* @alternate */ background-image: -moz-linear-gradient (POS, hsl (HSL1, HSL2, HSL3), COLOR); /* FF3.6+ */
08  
09 /* @alternate */ background-image: -ms-linear-gradient (POS, hsl (HSL1, HSL2, HSL3), COLOR); /* IE10 */
10  
11 /* @alternate */ background-image: -o-linear-gradient (POS, hsl (HSL1, HSL2, HSL3), COLOR); /* Opera 11.10+ */
12  
13 }
14  
15 .header {
16  
17 @mixin gradient (top0%, 50%, 70%, #cc0000#f07575);
18  
19 }

  结果如下:

view source
print ?
01 .header {
02  
03 background-color#f07575;
04  
05 background-image: -webkit-linear-gradient (top,hsl (0%,50%,70%) ,#cc0000);
06  
07 background-image: -moz-linear-gradient (top,hsl (0%,50%,70%) ,#cc0000);
08  
09 background-image: -ms-linear-gradient (top,hsl (0%,50%,70%) ,#cc0000);
10  
11 background-image: -o-linear-gradient (top,hsl (0%,50%,70%) ,#cc0000);
12  
13 }

  我们还可以使用 Closure Stylesheets 把多个 CSS 文件合并成一个,以减少代码的规模,它会针对语法执行静态检查,并且知道如何交换左右两边的值(RTL flipping),以及如何对类进行重命名。

  Closure Tools 是一组工具,其中包括编译器、程序库和模板,它原本是 Google 为 GMail、GDocs 和 Maps 内部使用,后来在2009年开源。我们可以使用它来处理大型 JavaScript 应用程序。

  查看英文原文:Google Closure Stylesheets Makes It Easier to Work with CSS

这篇关于Google Closure Stylesheets 让我们更易于使用CSS的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/695817

相关文章

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型

使用Pandas进行均值填充的实现

《使用Pandas进行均值填充的实现》缺失数据(NaN值)是一个常见的问题,我们可以通过多种方法来处理缺失数据,其中一种常用的方法是均值填充,本文主要介绍了使用Pandas进行均值填充的实现,感兴趣的... 目录什么是均值填充?为什么选择均值填充?均值填充的步骤实际代码示例总结在数据分析和处理过程中,缺失数

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基

Python使用getopt处理命令行参数示例解析(最佳实践)

《Python使用getopt处理命令行参数示例解析(最佳实践)》getopt模块是Python标准库中一个简单但强大的命令行参数处理工具,它特别适合那些需要快速实现基本命令行参数解析的场景,或者需要... 目录为什么需要处理命令行参数?getopt模块基础实际应用示例与其他参数处理方式的比较常见问http

C 语言中enum枚举的定义和使用小结

《C语言中enum枚举的定义和使用小结》在C语言里,enum(枚举)是一种用户自定义的数据类型,它能够让你创建一组具名的整数常量,下面我会从定义、使用、特性等方面详细介绍enum,感兴趣的朋友一起看... 目录1、引言2、基本定义3、定义枚举变量4、自定义枚举常量的值5、枚举与switch语句结合使用6、枚

使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)

《使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)》PPT是一种高效的信息展示工具,广泛应用于教育、商务和设计等多个领域,PPT文档中常常包含丰富的图片内容,这些图片不仅提升了... 目录一、引言二、环境与工具三、python 提取PPT背景图片3.1 提取幻灯片背景图片3.2 提取

使用Python实现图像LBP特征提取的操作方法

《使用Python实现图像LBP特征提取的操作方法》LBP特征叫做局部二值模式,常用于纹理特征提取,并在纹理分类中具有较强的区分能力,本文给大家介绍了如何使用Python实现图像LBP特征提取的操作方... 目录一、LBP特征介绍二、LBP特征描述三、一些改进版本的LBP1.圆形LBP算子2.旋转不变的LB

Maven的使用和配置国内源的保姆级教程

《Maven的使用和配置国内源的保姆级教程》Maven是⼀个项目管理工具,基于POM(ProjectObjectModel,项目对象模型)的概念,Maven可以通过一小段描述信息来管理项目的构建,报告... 目录1. 什么是Maven?2.创建⼀个Maven项目3.Maven 核心功能4.使用Maven H