压缩 css 代码可降低 css 文件大小,提高页面打开速度。

我们接着将规律转换为 gulp 代码

## [](https://github.com/nimojs/gulp-book/blob/master/chapter3.md#规律)规律

找到 `css/` 目录下的所有 css 文件,压缩它们,将压缩后的文件存放在 `dist/css/` 目录下。

## [](https://github.com/nimojs/gulp-book/blob/master/chapter3.md#gulp-代码)gulp 代码

你可以 [下载所有示例代码](https://github.com/nimojs/gulp-book/archive/master.zip) 或 [在线查看代码](https://github.com/nimojs/gulp-book/tree/master/demo/chapter3)

当熟悉 [使用 gulp 压缩 JS](https://github.com/nimojs/gulp-book/blob/master/chapter2.md) 的方法后,配置压缩 CSS 的 gulp 代码就变得很轻松。

**一、安装 gulp-minify-css** 模块

提示:你需要使用命令行的 `cd` 切换到对应目录后进行安装操作。

[学习使用命令行](https://github.com/nimojs/gulp-book/blob/master/chapter1.md)

在命令行输入

~~~

npm install gulp-minify-css

~~~

安装成功后你会看到如下信息:(安装时间可能会比较长)

~~~

gulp-minify-css@1.0.0 node_modules/gulp-minify-css

├── object-assign@2.0.0

├── vinyl-sourcemaps-apply@0.1.4 (source-map@0.1.43)

├── clean-css@3.1.8 (commander@2.6.0, source-map@0.1.43)

├── through2@0.6.3 (xtend@4.0.0, readable-stream@1.0.33)

├── vinyl-bufferstream@1.0.1 (bufferstreams@1.0.1)

└── gulp-util@3.0.4 (array-differ@1.0.0, beeper@1.0.0, array-uniq@1.0.2, lodash._reescape@3.0.0, lodash._reinterpolate@3.0.0, lodash._reevaluate@3.0.0, replace-ext@0.0.1, minimist@1.1.1, multipipe@0.1.2, vinyl@0.4.6, chalk@1.0.0, lodash.template@3.3.2, dateformat@1.0.11)

~~~

**二、参照 [使用 gulp 压缩 JS](https://github.com/nimojs/gulp-book/blob/master/chapter2.md) 创建 `gulpfile.js` 文件编写代码**

在对应目录创建 `gulpfile.js` 文件并写入如下内容:

~~~

// 获取 gulp

var gulp = require('gulp')

// 获取 minify-css 模块(用于压缩 CSS)

var minifyCSS = require('gulp-minify-css')

// 压缩 css 文件

// 在命令行使用 gulp css 启动此任务

gulp.task('css', function () {

// 1\. 找到文件

gulp.src('css/*.css')

// 2\. 压缩文件

.pipe(minifyCSS())

// 3\. 另存为压缩文件

.pipe(gulp.dest('dist/css'))

})

// 在命令行使用 gulp auto 启动此任务

gulp.task('auto', function () {

// 监听文件修改,当文件被修改则执行 css 任务

gulp.watch('css/*.css', ['css'])

});

// 使用 gulp.task('default') 定义默认任务

// 在命令行使用 gulp 启动 css 任务和 auto 任务

gulp.task('default', ['css', 'auto'])

~~~

你可以访问 [gulp-minify-css](https://github.com/jonathanepollack/gulp-minify-css) 以查看更多用法。

* * *

**三、创建 css 文件**

在 `gulpfile.js` 对应目录创建 `css` 文件夹,并在 `css/` 目录下创建 `a.css` 文件。

~~~

/* a.css */

body a{

color:pink;

}

~~~

* * *

**四、运行 gulp 查看效果**

在命令行输入 `gulp` +回车

你将看到命令行出现如下提示

~~~

gulp

[17:01:19] Using gulpfile ~/Documents/code/gulp-book/demo/chapter3/gulpfile.js

[17:01:19] Starting 'css'...

[17:01:19] Finished 'css' after 6.21 ms

[17:01:19] Starting 'auto'...

[17:01:19] Finished 'auto' after 5.42 ms

[17:01:19] Starting 'default'...

[17:01:19] Finished 'default' after 5.71 μs

~~~

gulp 会创建 `dist/css` 目录,并创建 `a.css` 文件,此文件存放压缩后的 css 代码。 [dist/css/a.css](https://github.com/nimojs/gulp-book/blob/master/demo/chapter3/dist/css/a.css)

gulp压缩css文件夹,使用 gulp 压缩 CSS相关推荐

  1. linux 压缩7z文件夹,Linux 下压缩与解压.zip和.rar及.7z文件

    Linux 下压缩与解压.zip和.rar及.7z文件对于Window下的常见压缩文件.zip和.rar,Linux也有相应的方法来解压它们: 1)对于.zip linux下提供了zip和unzip程 ...

  2. Java批量完成对文件夹下全部的css与js压缩,利用yuicompressor

    大部分代码我是从网上找的, 只有对文件的遍历是我自己写的: 其实原理十分简单 利用yuicompressor已经编好的方法,我们写一个Java程序来调用即可: yuicompressor-2.4.8. ...

  3. Python压缩目录文件夹,解压目录文件夹及耗时效率统计

    Python用zip_file压缩文件夹,用unzip_file解压文件夹 1. 压缩效果对比 发现压缩率挺低的 压缩前:28.9MB,压缩后依然:27.8MB 2. 压缩耗时 运用了Python 装 ...

  4. 压缩文件夹_怎样压缩文件夹并发送

    只需要在需要压缩的文件右键打开菜单,然后选择[添加到压缩文件]选项,点击确定等待压缩文件完成,然后使用[复制]-[粘贴]的方法,将压缩文件粘贴到QQ.微信或者是添加到邮箱即可.以下是详细介绍: 1.选 ...

  5. 【Auto.js】[zip压缩] 将文件夹压缩成zip包

    将一个文件夹压缩成一个zip包,可应用于项目文件夹打包成zip, 文件夹过滤了目录中的空文件夹,因此,空文件夹不会被打包到zip包中. 由于本人JS知识有限,JAVA也不懂, 导致该函数, 打包大型文 ...

  6. java 压缩文件夹_java 实现压缩文件(单文件 或 文件夹)

    接着上篇了解一下java压缩实现过程,下面的是支持 单文件 或 文件夹 压缩的实现,使用递归. 效果: 代码: package com.gx.compress; import java.io.Buff ...

  7. python的zipfile压缩文件夹_python zipfile压缩使用说明

    压缩 f=zipfile.ZipFile(file, mode="r", compression=ZIP_STORED, allowZip64=False) 创建一个zip文件对象 ...

  8. c语言程序压缩解压缩文件夹,【转】使用VC++压缩解压缩文件夹

    前言 项目中要用到一个压缩解压缩的模块, 看了很多文章和源代码, 都不是很称心, 现在把我自己实现的代码和大家分享. 要求: 1.使用Unicode(支持中文). 2.使用源代码.(不使用静态或者动态 ...

  9. Linux下文件(文件夹)的压缩和解压

    前言 在linux下,当我们上传一个较大的文件或者要安装一个软件(如tomcat.mysql等)时,我们需要先将官网下载的压缩包在linux服务器上进行解压,再进行安装.如果是由程序包生成的一个目录内 ...

最新文章

  1. Matlab实用程序--图形应用-变换的傅立叶函数曲线
  2. JAVA中String的一些常用函数用法总结
  3. Window10:不能建立到远程计算机的连接。你可能需要更改此连接的网络设置。
  4. VUE3 项目自定义修改网页标题和图标
  5. poj2976 Dropping tests
  6. 1.10 卷积神经网络示例
  7. 兆芯笔试题(2015)找反复数最多的字母的数量以及位置
  8. 剖析HotSpot的初始化过程
  9. 计算程序/函数运行时间
  10. 2018最新私塾在线高级java软件架构师实战培训
  11. 实验1:局域网的组建与配置
  12. TFIDF理解和应用
  13. APISpace 反欺诈(羊毛盾)API
  14. 【滴滴出行】2017秋招笔试真题(智力题)
  15. Python实现某du内容下载, 保存到word文档
  16. 分类之混淆矩阵(Confusion Matrix)
  17. 2018年日常小计汇总
  18. 把一个人的特点写具体作文_把一个人的特点写具体作文600字
  19. 【MindSpore易点通】安装教程
  20. 前端架构八大设计准则

热门文章

  1. UVa11292 - Dragon of Loowater (贪心+模拟)
  2. 如何掌握所有的程序设计语言?
  3. 【转】构建C1000K的服务器(1) – 基础
  4. 手机连接电脑wifi
  5. 一道面试题:猫大叫了一声...
  6. 9种深度学习算法简介
  7. CC2530通用I/O
  8. 互联网寒冬来袭,有一家公司却逆流而上!
  9. 三流面试问技术,二流面试问平台,一流面试……
  10. 写了4年博客,我终于也出了一本书。