利用gulp搭建简单服务器,gulp标准版
var gulp = require('gulp'),
autoprefixer = require('gulp-autoprefixer'), //自动添加css前缀
rename = require('gulp-rename'), //文件重命名
sass = require('gulp-sass'), //sass的编译
minifycss = require('gulp-minify-css'), //压缩css
uglify = require('gulp-uglify'), //压缩js代码
concat = require('gulp-concat'), //合并js文件
rev = require('gulp-rev'), //更改版本名
revCollector = require('gulp-rev-collector'), //rev的插件,用于更改html模版中lib的引用
del = require('del'), //清除文件
livereload = require('gulp-livereload'),
// babel = require('gulp-babel'),//清除文件
jade = require('gulp-jade'), //jade
htmlmin = require("gulp-htmlmin"), //html
connect = require('gulp-connect'), //使用connect启动一个Web服务器
js_pach = ['app/static/**.js', 'app/static/**/**.js', 'app/template/**.js', 'app/template/**/**.js', 'app/template/**/**.js'],
//var css_pach = ['css/ionic_main.css','css/huodong.css','css/gouwuche.css','css/chenggong.css'];
scss_pach = ['app/**/**.scss', 'app/**/**/**.scss', 'app/**/**/**/**.scss', 'app/**/**/**/**/**.scss'],
jade_path = ['app/template/**.jade', 'app/template/**/**.jade', 'app/template/**/**/**.jade', 'app/template/**/**/**/**.jade'],
jade2_path = ['app/static/**.jade', 'app/static/**/**.jade', 'app/static/**/**/**.jade'],
html_path = ['app/template/**.html', 'app/template/**/**.html', 'app/template/**/**/**.html', 'app/template/**/**/**/**.html'],
all_path = js_pach.concat(scss_pach).concat(jade_path).concat(jade2_path).concat(html_path);
gulp.task('connect', function () {
connect.server({
root: '',
livereload: true,
port: 8080 //服务器端口
});
});
// gulp.task('babel', function () {
// return gulp.src(js_pach)
// .pipe(babel({
// compact:false
// }))
// .pipe(concat('debug2.js'))
// .pipe(gulp.dest('js'));
// });
gulp.task('jade', function () {
return gulp.src(jade_path)
.pipe(jade()).on('error', function () {
console.log("eroror")
})
.pipe(gulp.dest('app/dist/templates')).pipe(connect.reload());
})
gulp.task('jade2', function () {
return gulp.src(jade2_path)
.pipe(jade()).on('error', function () {
console.log("eroror")
})
.pipe(gulp.dest('app/dist')).pipe(connect.reload());
});
gulp.task('html', function () {
return gulp.src(html_path)
.pipe(htmlmin({collapseWhitespace: true,minifyCSS:true,minifyJS:true,removeComments:true,removeEmptyAttributes:true}))
.pipe(gulp.dest('app/dist/templates')).pipe(connect.reload());
})
gulp.task('js', ['cleanjs'], function () {
return gulp.src(js_pach)
.pipe(concat('debug.js'))
.pipe(gulp.dest('app/dist/js'))
.pipe(concat('main.js'))
.pipe(uglify())
.pipe(rev())
.pipe(gulp.dest('app/dist/js'))
.pipe(rev.manifest())
.pipe(gulp.dest('app/dist/js'))
});
gulp.task('cleanjs', function (cb) {
return del(['app/dist/js/main-**.js'], cb)
});
gulp.task('cleancss', function (cb) {
return del(['app/dist/css/main-**.css'], cb)
});
gulp.task('jsrev', ['js'], function () {
return gulp.src(['app/dist/js/**.json', 'index.html'])
.pipe(revCollector({
replaceReved: true
}))
.pipe(gulp.dest('')).pipe(connect.reload())
});
gulp.task('sassrev', ['sass'], function () {
return gulp.src(['app/dist/css/**.json', 'index.html'])
.pipe(revCollector({
replaceReved: true
}))
.pipe(gulp.dest('')).pipe(connect.reload())
});
gulp.task('sass', ['cleancss'], function () {
return gulp.src(scss_pach)
.pipe(sass({
outputStyle: 'compressed'
}).on('error', sass.logError))
.pipe(concat('debug.css'))
.pipe(gulp.dest('app/dist/css'))
.pipe(concat('main.css'))
.pipe(rev())
.pipe(gulp.dest('app/dist/css'))
.pipe(rev.manifest())
.pipe(gulp.dest('app/dist/css'));
});
gulp.task('default', function () {
gulp.start('connect', 'watch');
});
//监视文件变化,自动生成到dist文件夹
gulp.task('watch', function () {
gulp.watch(js_pach, ['jsrev']);
gulp.watch(scss_pach, ['sassrev']);
gulp.watch(jade_path, ['jade']);
gulp.watch(jade2_path, ['jade2']);
gulp.watch(html_path, ['html']);
});
npm install --save 即可把所依赖的文件下载到本地

利用gulp搭建简单服务器,gulp标准版的更多相关文章
- 利用gulp搭建本地服务器,并能模拟ajax
工作中可能会用到的小工具,在此记录一下.可以实现的功能有: 本地http服务器 页面实时刷新 可以模拟ajax请求 第一步,新建package.json文件.用到了gulp.gulp-webserve ...
- 利用Serv-U搭建FTP服务器
以前在学校的时候,学校的整个宿舍楼都是在一个局域网中,经常有人用个人电脑搭个网站或者FTP啊什么的,主要是进行一些影视资源的传播活动.不乏 有些资源充沛的有志青年利用业余时间翻译某岛国影视资源,利用局 ...
- Node安装及搭建简单服务器
注:本文安装系统为mac,windows及其他系统下载对应安装包 ,mac下载后的安装包为apk文件,windows为msi文件. 安装 1.在网上下载node安装包,官方网站2.双击下载文件,按步骤 ...
- CentOS利用postfix搭建邮件服务器
之前我用nodemailer通过163邮箱来发送邮件,不过没过几天就一直ETIMEDOUT,不知道什么原因,想着还是自己搭一个来发邮件可能靠谱点(flag?) 安装postfix CentOS 7 自 ...
- 利用nginx搭建https服务器
一.HTTPS简介 HTTPS其实是有两部分组成:HTTP + SSL / TLS,也就是在HTTP上又加了一层处理加密信息的模块.服务端和客户端的信息传输都会通过TLS进行加密,所以传输的数据都是加 ...
- gulp 搭建静态服务器
步骤: 安装依赖:npm i browser-sync --save-dev 导入browser-sync,通过create创建 设置Sass和Js任务,将其压缩重命名并引入页面,任务结束时reloa ...
- 利用docker搭建rtmp服务器(1)
以后的项目里面可能需要用到直播,所以就先看看 本来想在自己MAC上搭建nginx的,后来怕把自己的机子搞乱,刚好就学习了下docker,感觉docker强大就在于是一个操作系统软件的版本管理系统,可以 ...
- 嵌入式Linux利用Wifi搭建无线服务器(物联网实践之无线网关)
在 http://www.cnblogs.com/heat-man/p/4564539.html中,在嵌入式Linux开发板上我们从最底层实现了一个智能家居的远程控制系统,然而采取的是用网线连接到交换 ...
- [PHP]利用XAMPP搭建本地服务器, 然后利用iOS客户端上传数据到本地服务器中(三. PHP端代码实现)
一.安装XAMPP http://www.cnblogs.com/lidongxu/p/5256330.html 二. 配置MySql http://www.cnblogs.com/lidongx ...
随机推荐
- Verilog读写文件
在通过编写Verilog代码实现ram功能时,需要自己先计算寄存器的位数和深度再编写代码. 而如果需要在编写的ram中预置值的话,就需要使用Verilog语言编写程序读写文件,来将相应的数据赋给寄存器 ...
- XAF-通知模块概述 web+win
通知模块概述 1.支持 WinForms和ASP.NET程序. 2.支持调度模块或自定义业务对象. 3.功能:在指定的时间,弹出一个窗口,用户可以查看提醒.也可以取消或推迟. 如需演示项目的源码,可以 ...
- 性能测试分享:jmeter性能监控(一)
性能测试分享:jmeter性能监控(一) poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣,请大家咨询qq:908 ...
- 性能测试分享: Jmeter的源码分析main函数参数
性能测试分享: Jmeter的源码分析main函数参数 poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣,请大 ...
- 手机自动化测试:Appium源码分析之跟踪代码分析五
手机自动化测试:Appium源码分析之跟踪代码分析五 手机自动化测试是未来很重要的测试技术,作为一名测试人员应该熟练掌握,POPTEST举行手机自动化测试的课程,希望可以训练出优秀的手机测试开发工 ...
- 纯JS写动态分页样式效果
效果图如下: html: <body> <div> <table id="btnbox"> <tbody> <tr>&l ...
- c/c++程序员的技术栈
在当今的互联网时代, java, 安卓, ios, 大行其道,而c/c++却显得越来越落寞. 其实这并不是c/c++程序员本身的问题,而是这是一个产品快速响应市场的年代.用过c/c++的人都知道, ...
- C语言求最小公倍数和最大公约数三种算法(经典)
把以前写的一些经验总结汇个总,方便给未来的学弟学妹们做个参考! --------------------------永远爱你们的:Sakura 最小公倍数:数论中的一种概念,两个整数公有的倍数成为他们 ...
- java 基础知识九 类与对象
java 基础知识九 类与对象 1.OO(Object–Oriented )面向对象,OO方法(Object-Oriented Method,面向对象方法,面向对象的方法)是一种把面向对象的思想应 ...
- ARM中断处理过程
以s3c2440 ARM9核为例: 一:s3c2440 ARM处理器特性: 1.S3C2440支持个中断源,含子中断源: 2.ARM9采用五级流水线方式: 3.支持外部中断和内部中断: 二.s3c2 ...