美文网首页
gulp 实现 js、css,img 合并和压缩

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

作者: 星禾君 | 来源:发表于2017-08-20 16:03 被阅读33次
  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

相关文章

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

    安装nodejs; 新建package.json文件; 全局安装gulp;全局安装gulp目的是为了通过她执行gu...

  • gulp与webpack区别

    Gulp和Webpack的基本区别: gulp可以进行js,html,css,img的压缩打包,是自动化构建工具,...

  • gulp-css压缩

    gulp是什么?使用 gulp 实现图片压缩、CSS 压缩合并、JS 压缩合并 gulp是一个基于流的构建工具,可...

  • gulp浅显易懂的入门

    gulp是什么? gulp是工具链、构建工具,可以配合各种插件做js压缩,css压缩,less编译 替代手工实现自...

  • Gulp 使用gulp压缩CSS

    我们除了可以使用 gulp 压缩 JS 文件,还可以压缩 CSS,压缩 CSS 代码可以降低 CSS 文件的大小,...

  • Gulp 使用gulp压缩CSS

    我们除了可以使用 gulp 压缩 JS 文件,还可以压缩 CSS,压缩 CSS 代码可以降低 CSS 文件的大小,...

  • gulp插件(2) - gulp-clean-css(压缩CSS

    功能描述 gulp-clean-css用于css文件压缩 gulp-minify-css也是实现相同功能,但gul...

  • gulp vs webpack

    gulp是工具链、构建工具,可以配合各种插件做js压缩,css压缩,less编译 替代手工实现自动化工作 构建工具...

  • gulp和webpack的区别 // less和scss

    gulp是工具链、构建工具,可以配合各种插件做js压缩,css压缩,less编译 替代手工实现自动化工作1.构建工...

  • 前端自动化工具|gulp新手入门

    gulp是前端自动化工具,它可以进行html压缩、css压缩合并、js检查压缩、图片压缩、编译less、编译...

网友评论

      本文标题:gulp 实现 js、css,img 合并和压缩

      本文链接:https://www.haomeiwen.com/subject/tnmfdxtx.html