Skip to content

Instantly share code, notes, and snippets.

@paulmsmith
Forked from dstroot/app.js
Created October 25, 2017 14:56
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save paulmsmith/383df3255c18ab2c93734a58be3b32a8 to your computer and use it in GitHub Desktop.
Save paulmsmith/383df3255c18ab2c93734a58be3b32a8 to your computer and use it in GitHub Desktop.
Gulp, BrowserSync, Node, and Nodemon all working in harmony. ;)
/**
* World's simplest express server
* - used to serve index.html from /public
*/
var express = require('express');
var serveStatic = require('serve-static');
var app = express();
app.use(serveStatic(__dirname + '/public'));
app.listen(3000);
console.log('Express listening on port 3000');
/**
* Module Dependencies
*/
var gulp = require('gulp');
var browserSync = require('browser-sync');
var reload = browserSync.reload;
var nodemon = require('gulp-nodemon');
/**
* Gulp Tasks
*/
gulp.task('browser-sync', ['nodemon'], function() {
browserSync({
proxy: "localhost:3000", // local node app address
port: 5000, // use *different* port than above
notify: true
});
});
gulp.task('nodemon', function (cb) {
var called = false;
return nodemon({
script: 'app.js',
ignore: [
'gulpfile.js',
'node_modules/'
]
})
.on('start', function () {
if (!called) {
called = true;
cb();
}
})
.on('restart', function () {
setTimeout(function () {
reload({ stream: false });
}, 1000);
});
});
gulp.task('default', ['browser-sync'], function () {
gulp.watch(['public/*.html'], reload);
});
{
"private": true,
"dependencies": {
"express": "^4.5.1",
"serve-static": "^1.3.0"
},
"devDependencies": {
"browser-sync": "^1.2.1",
"gulp": "^3.8.6",
"gulp-nodemon": "^1.0.4"
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment