gulp 实现 js、css,img 合并和压缩

  1. 安装nodejs

  2. 新建package.json文件;

  3. 全局安装gulp
    全局安装gulp目的是为了通过她执行gulp任务: cnpm install gulp -g

  4. 新建package.json文件
    cnpm init

  5. 本地安装gulp
    为了能正常使用,我们还得本地安装gulp:cnpm install gulp --save-dev

  6. 安装gulp插件;

cnpm install gulp-htmlmin gulp-imagemin imagemin-pngcrush gulp-minify-css gulp-jshint gulp-uglify gulp-concat gulp-rename gulp-notify --save-dev
  1. 新建gulpfile.js文件;
// 在你的项目根目录下创建gulpfile.js,代码如下:
 // 引入 gulp
    var gulp = require('gulp');
     
    // 引入组件
    var htmlmin = require('gulp-htmlmin'), //html压缩
        imagemin = require('gulp-imagemin'),//图片压缩
        pngcrush = require('imagemin-pngcrush'),
        minifycss = require('gulp-minify-css'),//css压缩
        jshint = require('gulp-jshint'),//js检测
        uglify = require('gulp-uglify'),//js压缩
        concat = require('gulp-concat'),//文件合并
        rename = require('gulp-rename'),//文件更名
        notify = require('gulp-notify');//提示信息
     
    // 压缩html
    gulp.task('html', function() {
      return gulp.src('src/*.html')
        .pipe(htmlmin({collapseWhitespace: true}))
        .pipe(gulp.dest('./dest'))
        .pipe(notify({ message: 'html task ok' }));
     
    });
     
    // 压缩图片
    gulp.task('img', function() {
      return gulp.src('src/images/*')
        .pipe(imagemin({
            progressive: true,
            svgoPlugins: [{removeViewBox: false}],
            use: [pngcrush()]
        }))
        .pipe(gulp.dest('./dest/images/'))
        .pipe(notify({ message: 'img task ok' }));
    });
     
    // 合并、压缩、重命名css
    gulp.task('css', function() {
      return gulp.src('src/css/*.css')
        .pipe(concat('main.css'))
        .pipe(gulp.dest('dest/css'))
        .pipe(rename({ suffix: '.min' }))
        .pipe(minifycss())
        .pipe(gulp.dest('dest/css'))
        .pipe(notify({ message: 'css task ok' }));
    });
     
    // 检查js
    gulp.task('lint', function() {
      return gulp.src('src/js/*.js')
        .pipe(jshint())
        .pipe(jshint.reporter('default'))
        .pipe(notify({ message: 'lint task ok' }));
    });
     
    // 合并、压缩js文件
    gulp.task('js', function() {
      return gulp.src('src/js/*.js')
        .pipe(concat('all.js'))
        .pipe(gulp.dest('dest/js'))
        .pipe(rename({ suffix: '.min' }))
        .pipe(uglify())
        .pipe(gulp.dest('dest/js'))
        .pipe(notify({ message: 'js task ok' }));
    });
     
    // 默认任务
    gulp.task('default', function(){
      gulp.run('img', 'css', 'lint', 'js', 'html');
     
      // 监听html文件变化
      gulp.watch('src/*.html', function(){
        gulp.run('html');
      });
     
      // Watch .css files
      gulp.watch('src/css/*.css', ['css']);
     
      // Watch .js files
      gulp.watch('src/js/*.js', ['lint', 'js']);
     
      // Watch image files
      gulp.watch('src/images/*', ['img']);
    }); 
  1. 通过命令提示符运行gulp任务。
    gulp default
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 前言 众所周知目前比较火的工具就是gulp和webpack,但webpack和gulp却有所不同,本人两者的底层研...
    cduyzh阅读 5,224评论 0 13
  • 简介:gulp是前端开发过程中对代码进行构建的工具,是自动化项目的构建利器;她不仅能对网站资源进行优化,而且在开发...
    情怀水岸阅读 4,278评论 0 5
  • 什么是GULP? GULP 是前端开发过程中对代码进行构建的工具,是自动化项目的构建利器;她不仅能 对...
    碧玉含香阅读 3,899评论 0 0
  • 1、gulp的安装 首先确保你已经正确安装了nodejs环境。然后以全局方式安装gulp: npm install...
    F_imok阅读 7,034评论 1 11
  • 在学习前,先谈谈大致使用gulp的步骤,给读者以初步的认识。首先当然是安装nodejs,通过nodejs的npm全...
    amazing_bing阅读 4,678评论 0 1

友情链接更多精彩内容