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

相关文章

从零教你安装pytorch并在pycharm中使用

《从零教你安装pytorch并在pycharm中使用》本文详细介绍了如何使用Anaconda包管理工具创建虚拟环境,并安装CUDA加速平台和PyTorch库,同时在PyCharm中配置和使用PyTor... 目录背景介绍安装Anaconda安装CUDA安装pytorch报错解决——fbgemm.dll连接p

Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)

《Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)》文章介绍了如何使用dhtmlx-gantt组件来实现公司的甘特图需求,并提供了一个简单的Vue组件示例,文章还分享了一... 目录一、首先 npm 安装插件二、创建一个vue组件三、业务页面内 引用自定义组件:四、dhtmlx

使用Python创建一个能够筛选文件的PDF合并工具

《使用Python创建一个能够筛选文件的PDF合并工具》这篇文章主要为大家详细介绍了如何使用Python创建一个能够筛选文件的PDF合并工具,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录背景主要功能全部代码代码解析1. 初始化 wx.Frame 窗口2. 创建工具栏3. 创建布局和界面控件4

一文详解如何在Python中使用Requests库

《一文详解如何在Python中使用Requests库》:本文主要介绍如何在Python中使用Requests库的相关资料,Requests库是Python中常用的第三方库,用于简化HTTP请求的发... 目录前言1. 安装Requests库2. 发起GET请求3. 发送带有查询参数的GET请求4. 发起PO

Java中的Cursor使用详解

《Java中的Cursor使用详解》本文介绍了Java中的Cursor接口及其在大数据集处理中的优势,包括逐行读取、分页处理、流控制、动态改变查询、并发控制和减少网络流量等,感兴趣的朋友一起看看吧... 最近看代码,有一段代码涉及到Cursor,感觉写法挺有意思的。注意是Cursor,而不是Consumer

Vue ElementUI中Upload组件批量上传的实现代码

《VueElementUI中Upload组件批量上传的实现代码》ElementUI中Upload组件批量上传通过获取upload组件的DOM、文件、上传地址和数据,封装uploadFiles方法,使... ElementUI中Upload组件如何批量上传首先就是upload组件 <el-upl

前端知识点之Javascript选择输入框confirm用法

《前端知识点之Javascript选择输入框confirm用法》:本文主要介绍JavaScript中的confirm方法的基本用法、功能特点、注意事项及常见用途,文中通过代码介绍的非常详细,对大家... 目录1. 基本用法2. 功能特点①阻塞行为:confirm 对话框会阻塞脚本的执行,直到用户作出选择。②

Node.js net模块的使用示例

《Node.jsnet模块的使用示例》本文主要介绍了Node.jsnet模块的使用示例,net模块支持TCP通信,处理TCP连接和数据传输,具有一定的参考价值,感兴趣的可以了解一下... 目录简介引入 net 模块核心概念TCP (传输控制协议)Socket服务器TCP 服务器创建基本服务器服务器配置选项服

如何使用CSS3实现波浪式图片墙

《如何使用CSS3实现波浪式图片墙》:本文主要介绍了如何使用CSS3的transform属性和动画技巧实现波浪式图片墙,通过设置图片的垂直偏移量,并使用动画使其周期性地改变位置,可以创建出动态且具有波浪效果的图片墙,同时,还强调了响应式设计的重要性,以确保图片墙在不同设备上都能良好显示,详细内容请阅读本文,希望能对你有所帮助...

CSS3 最强二维布局系统之Grid 网格布局

《CSS3最强二维布局系统之Grid网格布局》CS3的Grid网格布局是目前最强的二维布局系统,可以同时对列和行进行处理,将网页划分成一个个网格,可以任意组合不同的网格,做出各种各样的布局,本文介... 深入学习 css3 目前最强大的布局系统 Grid 网格布局Grid 网格布局的基本认识Grid 网