使用gulp实现文件压缩及浏览器热加载

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用gulp实现文件压缩及浏览器热加载相关的知识,希望对你有一定的参考价值。

一.安装gulp

  首先,你要安装过nodejs,如果没有安装过的同学请自行下载。  先再命令行里输入   npm install gulp -g   下载gulp

二.创建gulp项目

  创建一个你需要项目文件夹,然后在根目录输入  npm init  (npm init命令会为你创建一个package.json文件,这个文件保存着这个项目相关信息。比如你用到的各种依赖)

三.使用npm install 安装各种依赖 

  例:npm install browser-sync--save-dev

  技术分享

  这里总共用到了这些依赖,请自行下载   具体各自都有什么用 后面会具体介绍。

四.编写gulpfile.js

  首先,声明这些依赖

  技术分享

  然后我们就要开始最重要的工作了,配置这些依赖

  1.配置压缩css

  技术分享

  2.配置压缩js

  技术分享

  3.配置压缩img

  技术分享

  4.配置html,这里没有进行压缩,感觉没有压缩的必要 (纯属见仁见智)

  技术分享

  5.配置清楚文件,因为每次打包都会生成新文件  所以在这之前要把之前的文件给清除掉

  技术分享

  6.配置浏览器热加载

  技术分享

  7.配置打包   

  这里的runSequence是指能同时执行多个命令

  技术分享

  8.设置gulp启动时执行哪些配置

  技术分享

 

  最后放上全部代码 供大家参考

  

var gulp = require(‘gulp‘);
var sass = require(‘gulp-sass‘);
var browserSync = require(‘browser-sync‘);
var uglify = require(‘gulp-uglify‘);
var imagemin = require(‘gulp-imagemin‘);
var minifyCSS  = require(‘gulp-minify-css‘);
var cache = require(‘gulp-cache‘);
var del = require(‘del‘);
var runSequence = require(‘run-sequence‘);
var minifyHtml= require("gulp-minify-html");

gulp.task(‘sass‘, function(){   //打包sass
  return gulp.src(‘app/scss/**/*.scss‘)
    .pipe(sass()) // Converts Sass to CSS with gulp-sass
    .pipe(gulp.dest(‘app/css‘))
    .pipe(browserSync.reload({
      stream: true
    }))
});

gulp.task(‘js‘,function() {

    gulp.src(‘app/**/*.js‘)

    .pipe(uglify())//压缩

    .pipe(gulp.dest(‘dist‘));

});

gulp.task(‘css‘, function () {
    gulp.src(‘app/css/*.css‘)
    .pipe(minifyCSS())
    .pipe(gulp.dest(‘dist/css‘))
})

gulp.task(‘minify-html‘,function() {

      gulp.src(‘app/**/*.html‘)//要压缩的html文件
     .pipe(gulp.dest(‘dist‘));

});


gulp.task(‘images‘, function(){
  return gulp.src(‘app/images/**/*.+(png|jpg|jpeg|gif|svg)‘)
  // Caching images that ran through imagemin
  .pipe(cache(imagemin({
      interlaced: true
    })))
  .pipe(gulp.dest(‘dist/images‘))
});

gulp.task(‘clean‘, function(callback) {
  del(‘dist‘);
  return cache.clearAll(callback);
});

gulp.task(‘watch‘,[‘browserSync‘, ‘sass‘],function(){   //我们可以在watch任务之前告知Gulp,先把browserSync和Sass任务执行了再说。
  gulp.watch(‘app/scss/**/*.scss‘, [‘sass‘]);
  gulp.watch(‘app/*.html‘, browserSync.reload);
  gulp.watch(‘app/js/**/*.js‘, browserSync.reload);
  // Other watchers
});

gulp.task(‘browserSync‘, function() {  //浏览器热加载
  browserSync({
    server: {
      baseDir: ‘app‘
    },
  })
});

gulp.task(‘build‘, function (callback) {
  runSequence(‘clean‘,[‘minify-html‘,‘js‘,‘images‘,‘css‘],callback)
});

gulp.task(‘default‘, function (callback) {
  runSequence([‘sass‘,‘browserSync‘, ‘watch‘],
    callback
  )
});

 

以上是关于使用gulp实现文件压缩及浏览器热加载的主要内容,如果未能解决你的问题,请参考以下文章

gulp能做什么,前端装逼为何要用它

玩转gulp之压缩打包热重载

[万字详解,学习案例] 使用 gulp 去进行自动化构建一个项目

gulp打包压缩js代码

前端工具-浏览器同步测试(自动刷新热刷新热加载)

前端工具-浏览器同步测试(自动刷新热刷新热加载)