使用gulp+browser-sync搭建Sass自动化编译以及自动刷新所需要的插件

栏目: 编程工具 · 发布时间: 6年前

内容简介:1、安装全局gulp2、初始化package.jsonnpm init
npm install --save-dev gulp-concat//js合并插件

npm install --save-dev gulp-uglify//js压缩插件

npm install --save-dev gulp-cssnano//css压缩插件

npm install --save-dev gulp-imagemin//图片压缩插件

npm install --save-dev gulp-htmlmin//html压缩插件

npm install --save-dev del//文件删除模块

npm install --save-dev gulp merge-stream//在一个任务中使用多个文件来源

搭建gulp环境

按装gulp

1、安装全局gulp

npm install gulp -g

2、初始化package.json

npm init

3、在本项目安装引入的gulp

npm install gulp --save-dev

4、在本项目按照sass相关插件

npm install --save-dev gulp-sass

5、本步骤按需求来按照,下面gulp相关插件可以搭建完整的css、js相关压缩

npm install --save-dev gulp-concat gulp-uglify gulp-cssnano gulp-imagemin gulp-htmlmin merge-stream

配置gulpfile.js

在项目根目录中新建gulpfile.js文件(重要!!!文件名为固定不变的。)输入以下内容:

const gulp = require('gulp'); //获取gulp
const sass = require('gulp-sass');  //获取gulp
const browsersync = require('browser-sync').create(); //获取browsersync
const cssnano = require('gulp-cssnano'); //css压缩插件
const merge = require('merge-stream');

//操作css文件
/**
*  如果是一个任务处理多文件夹的话,
*  只要声明不同的变量,
*  然后return merge(xx, xx)合并返回即可
*  如下 style 任务
*/
gulp.task('style', function() {
    const scssIndex = gulp.src('./common/scss/*.scss')  //需要编译scss的文件
    .pipe(sass({outputStyle: 'compressed'})   //压缩格式:nested(嵌套)、compact(紧凑)、expanded(扩展)、compressed(压缩)
    .on('error', sass.logError))
    .pipe(cssnano())                 //css压缩
    .pipe(gulp.dest('./common/css'))    //输出路径
    .pipe(browsersync.stream());    //文件有更新自动执行

    const scssComponents = gulp.src('./common/components-scss/*.scss')  //需要编译scss的文件
    .pipe(sass({outputStyle: 'compressed'})   //压缩格式:nested(嵌套)、compact(紧凑)、expanded(扩展)、compressed(压缩)
    .on('error', sass.logError))
    .pipe(cssnano())                 //css压缩
    .pipe(gulp.dest('./common/components-css'))    //输出路径
    .pipe(browsersync.stream());    //文件有更新自动执行
    return merge(scssIndex, scssComponents);
});

//监听scss文件
gulp.task('serve',function() {
    gulp.start('style');
    gulp.watch('./common/scss/*.scss', ['style']);
    gulp.watch('./common/components-scss/*.scss', ['style']);
});

//编译scss文件:gulp default
gulp.task('default',['serve']);

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

C++标准库(第2版)

C++标准库(第2版)

Nicolai M. Josuttis / 侯捷 / 电子工业出版社 / 2015-6 / 186.00元

《C++标准库(第2版)》是全球C++经典权威参考书籍时隔12年,基于C++11标准的全新重大升级。标准库提供了一组公共类和接口,极大地拓展了C++语言核心功能。《C++标准库(第2版)》详细讲解了每一标准库组件,包括其设计目的和方法、复杂概念的剖析、实用而高效的编程细节、存在的陷阱、重要的类和函数,又辅以大量用C++11标准实现的实用代码范例。除覆盖全新组件、特性外,《C++标准库(第2版)》一......一起来看看 《C++标准库(第2版)》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

SHA 加密
SHA 加密

SHA 加密工具

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具