Skip to content

Instantly share code, notes, and snippets.

@waqashassan98
Created April 18, 2019 13:14
Show Gist options
  • Save waqashassan98/9a2df9ab7efdc915214d9ad14ea39376 to your computer and use it in GitHub Desktop.
Save waqashassan98/9a2df9ab7efdc915214d9ad14ea39376 to your computer and use it in GitHub Desktop.
Setup basic gulp file to compile sass and minify js
/*
NPM Setup
npm init
npm install -g gulp
npm install --save-dev gulp
npm install jshint gulp-jshint gulp-sass gulp-concat gulp-uglify gulp-rename --save-dev
*/
// Include gulp
var gulp = require('gulp');
// Include Our Plugins
var jshint = require('gulp-jshint');
var sass = require('gulp-sass');
var concat = require('gulp-concat');
var uglify = require('gulp-uglify');
var rename = require('gulp-rename');
// Lint Task
gulp.task('lint', function() {
return gulp.src('js/*.js')
.pipe(jshint())
.pipe(jshint.reporter('default'));
});
// Compile Our Sass
gulp.task('sass', function() {
return gulp.src('scss/*.scss')
.pipe(sass())
.pipe(gulp.dest('dist/css'));
});
// Concatenate & Minify JS
gulp.task('scripts', function() {
return gulp.src('js/*.js')
.pipe(concat('all.js'))
.pipe(gulp.dest('dist'))
.pipe(rename('all.min.js'))
.pipe(uglify())
.pipe(gulp.dest('dist/js'));
});
// Watch Files For Changes
gulp.task('watch', function() {
gulp.watch('js/*.js', ['lint', 'scripts']);
gulp.watch('scss/*.scss', ['sass']);
});
// Default Task
gulp.task('default', ['lint', 'sass', 'scripts', 'watch']);
@waqashassan98
Copy link
Author

Gulp only has 5 methods. These methods are as follows: task, run, watch, src, and dest.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment