gulp实战篇,看了那么多,动手才最主要

Posted 前端玩法

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了gulp实战篇,看了那么多,动手才最主要相关的知识,希望对你有一定的参考价值。

点击上方 “公众号” 可以订阅哦!

前面几篇讲了很多理论,那么今天我们一起来看实战的例子

安装Node.js

先在命令行下输入 node -v 检查一下是否装了node, 如果没有请参考 https://github.com/joyent/node/wiki/Installing-Node.js-via-package-manager 安装

然后再用 npm -v 来确保Node.js 安装正确

安装 Gulp

我们可以使用npm来安排装Gulp, 为了可以在命令行全局使用,我们安装到全局,另外确保其它的程序员可以使用,我们保存到项目的package.json里

npm install gulp -g

创建项目

创建一个文件目录,然后建立对应的文件夹

  • src — 源文件:

    • images 

    • scripts 

    • styles 

  • build — 编译后文件输出到的生产文件夹:

  • images 

  • scripts 

  • styles 

我们先使用npm init来创建类似Nuget package的package.config一样的文件,这样我们就知道项目依赖哪些插件,而且我们不需要把插件提交到代码库,其它程序员只需要使用 npm install 就可以安装所有配置的插件

然后我们需要创建一个gulpfile.js文件,gulp默认是调用这个文件的。

我们在目录下使用

  npm install gulp --save-dev  # 这样可以把gulp安装到本地

gulp实战篇,看了那么多,动手才最主要

使用插件

比如我们想检查我们的js文件,那么我们需要安装 gulp-jshint插件

  npm install gulp-jshint --save-dev

然后添加一个test.js文件到src/scripts下,内容如下

var hi="hello"function sayHello(){    console.log("Jack "+hi)
}

jshint 代码检查

然后我们修改gulpfile.js内容如下

// include gulpvar gulp = require('gulp'); 

// include plug-insvar jshint = require('gulp-jshint');// JS hint taskgulp.task('jshint', function() {
    gulp.src('./src/scripts/*.js')
      .pipe(jshint())
      .pipe(jshint.reporter('default'));
});

然后运行

gulp jshint

gulp实战篇,看了那么多,动手才最主要

看控制台输出就知道我们少了分号。

代码合并压缩

我们新建一个 ./scripts/b.js, 然后我们把js文件合并然后压缩并输出到./build/scripts/all.js 下,同时移除debug信息

我们需要安装一下插件

npm install gulp-concat --save-dev npm install gulp-strip-debug --save-dev npm install gulp-uglify --save-dev

修改gulpfile.js

var gulp = require('gulp'); 
var concat = require('gulp-concat');var stripDebug = require('gulp-strip-debug');var uglify = require('gulp-uglify');

gulp.task('scripts', function() {
  gulp.src(['./src/scripts/*.js'])
    .pipe(concat('all.js'))
    .pipe(stripDebug())
    .pipe(uglify())
    .pipe(gulp.dest('./build/scripts/'));
});

gulp实战篇,看了那么多,动手才最主要

我们看到gulp已经把我们文件合并了,移除了console.log, 而且进行了压缩。

至此,已经基本上知道gulp怎么使用了,下面展示一些其它的功能的代码

npm install gulp-autoprefixer --save-dev npm install gulp-minify-css --save-dev 

示例代码

var gulp = require('gulp'); 
var concat = require('gulp-concat');var stripDebug = require('gulp-strip-debug');var uglify = require('gulp-uglify');var autoprefix = require('gulp-autoprefixer');var minifyCSS = require('gulp-minify-css');

gulp.task('scripts', function() {
  gulp.src(['./src/scripts/*.js'])
    .pipe(concat('all.js'))
    .pipe(stripDebug())
    .pipe(uglify())
    .pipe(gulp.dest('./build/scripts/'));
});// CSS concat, auto-prefix and minifygulp.task('styles', function() {
  gulp.src(['./src/styles/*.css'])
    .pipe(concat('styles.css'))
    .pipe(autoprefix('last 2 versions'))
    .pipe(minifyCSS())
    .pipe(gulp.dest('./build/styles/'));
});// default gulp taskgulp.task('default', [ 'scripts', 'styles'], function() {   

// watch for JS changesgulp.watch('./src/scripts/*.js', function() {
    gulp.run('jshint', 'scripts');
  });// watch for CSS changes
    gulp.watch('./src/styles/*.css', function() {
        gulp.run('styles');
  });
});

至此,大家应该熟悉gulp的使用,尽情去挖掘gulp plugin的宝藏吧。



前端玩法

微信:web_html


一起玩前端

长按二维码关注


以上是关于gulp实战篇,看了那么多,动手才最主要的主要内容,如果未能解决你的问题,请参考以下文章

多线程全网爬取6500只基金|实战技巧篇

《nodejs+gulp+webpack基础实战篇》课程笔记--webpack篇

《nodejs+gulp+webpack基础实战篇》课程笔记-- 实战演练

《nodejs+gulp+webpack基础实战篇》课程笔记--gulp速度上手

《nodejs+gulp+webpack基础实战篇》课程笔记-- 实战演练,构建用户登录

《nodejs+gulp+webpack基础实战篇》课程笔记--利用gulp自动完成配置"吐"给webpack执行