Gulp 简单的开发环境搭建

//获取gulp
//require()是 node (CommonJS)中获取模块的语法 var gulp=require('gulp'); //获取gulp-concat模块(用于合并文件):npm install --save-dev gulp-concat
var concat=require('gulp-concat'); //获取gulp-jshint(语法检查):npm install jshint
var jshint=require('gulp-jshint'); //获取gulp-uglify组件(用于压缩JS):npm install gulp-uglify
var uglify=require('gulp-uglify'); //获取minify-css模块(用于压缩CSS):npm install gulp-minify-css
var minifyCSS=require('gulp-minify-css'); //获取gulp-imagemin模块:npm instal gulp-imagemin
var imagemin=require('gulp-imagemin'); //获取gulp-less 模块:npm install gulp-less
var less=require('gulp-less'); //获取gulp-ruby-sass模块:npm install gulp-ruby-sass@1.0.1
/*var sass=require('gulp-ruby-sass');*/ //获取gulp-sass模块:不依赖ruby环境,依赖包:node-sass
var sass=require('gulp-sass'); //获取gulp-minify-html模块:npm i gulp-minify-html
var minifyHtml=require('gulp-minify-html'); //获取gulp-autoprefixer模块:npm i gulp-autoprefixer
var autoprefixer = require('gulp-autoprefixer'); //获取gulp-watch-path模块:npm install gulp-watch-path
//var watchPath=require('gulp-watch-path'); //获取gulp-rename(文件重命名):npm install gulp-rename
var rename=require('gulp-rename'); //创建任务 // 语法检查
gulp.task('jshint', function () {
return gulp.src('js/*.js')
.pipe(jshint())
.pipe(jshint.reporter('default'));
}); //压缩js文件
//在命令行中使用gulp script启动此任务 gulp.task('script',function(){
//1.找到文件
gulp.src('js/*.js')
//2.压缩文件
.pipe(uglify())
//3.压缩后另存文件
.pipe(gulp.dest('dist/js'))
}); //创建压缩css任务 gulp.task('css',function(){
//1.找到文件
gulp.src('css/*.css')
//2.压缩文件
.pipe(minifyCSS())
//3.另存为压缩文件
.pipe(gulp.dest('dist/css'))
//4.压缩后的文件重命名为:xx.min.css
.pipe(rename({suffix:'.min'}))
.pipe(autoprefixer())
.pipe(minifyCSS())
.pipe(gulp.dest('dist/css'))
}); //创建压缩图片任务
//在命令行输入 gulp images 启动此任务 gulp.task('images',function(){
//1.找到图片
gulp.src('images/*.*')
//2.压缩图片
.pipe(imagemin({
progressive:true
}))
//3.另存压缩后图片
.pipe(gulp.dest('dist/images'))
}); //压缩HTML文件
//在命令行输入 gulp minifyHTML 启动此任务 gulp.task('html', function () {
gulp.src('html/*.html') // 要压缩的html文件
.pipe(minifyHtml()) //压缩
.pipe(gulp.dest('dist/html'));
}); //编译less
//在命令行输入 gulp less 启动此任务 gulp.task('less',function(){
//1.找到 less 文件
gulp.src('less/**.less')
//2.编译为css
.pipe(less())
//3.另存文件
.pipe(gulp.dest('dist/css'))
//4.重命名,并压缩
.pipe(rename({suffix:'.min'}))
.pipe(minifyCSS())
.pipe(gulp.dest('dist/min/css'))
}); //编译sass
//在命令行输入 gulp sass启动此任务 gulp.task('sass', function() {
gulp.src('sass/*.scss')
.pipe(sass())
.pipe(gulp.dest('dist/css'))
.pipe(rename({suffix:'.min'}))
.pipe(minifyCSS())
.pipe(gulp.dest('dist/min/css'))
}); //文件合并
gulp.task('concat', function () {
gulp.src('js/*.js') //要合并的文件
.pipe(concat('all.js')) // 合并匹配到的js文件并命名为 "all.js"
.pipe(gulp.dest('dist/js'))
.pipe(rename({suffix:'.min'}))
.pipe(uglify())
.pipe(gulp.dest('dist/js'))
}); //autoprefixer,自动补全css3前缀 gulp.task('autoprefixer',function(){
return gulp.src('css/*.css')
.pipe(autoprefixer({
browsers:['last 2 version'],
cascade:false
}))
.pipe(gulp.dest('dist/css'))
}) //自动监听:当文件修改时候,自动执行script任务 //在命令行使用gulp watch 启动以下任务
gulp.task('watch',function(){
gulp.watch('js/*.js',['jshint','script','concat']);
gulp.watch('sass/*.scss',['sass','css','autoprefixer']);
gulp.watch('css/*.css',['css','autoprefixer']);
gulp.watch('html/*.html',['html']);
}); //使用gulp.task('default') 定义默认任务,即:输入 gulp script 指令时默认启动该任务
//在命令行使用 gulp 启动 script 任务 和 auto 任务
//停止自动任务:Ctrl + C
//多任务执行 gulp +回车 gulp.task('default',['jshint','autoprefixer','script','css','html','images','sass','less','watch']);
Gulp 简单的开发环境搭建的更多相关文章
- android Jni NDK开发环境搭建及其简单实例的编写
android Jni NDK开发环境搭建及其简单实例的编写 由于工作需要,需要采用开发想要的JNI,由于之前没有接触过安卓的开发,所以更加网上的帖子,学习了下.遇到了些问题,然后总结下学习过程中 ...
- Struts2开发环境搭建,及一个简单登录功能实例
首先是搭建Struts2环境. 第一步 下载Struts2去Struts官网 http://struts.apache.org/ 下载Struts2组件.截至目前,struts2最新版本为2.3.1. ...
- 如何学习web开发环境搭建和脚手架
Web前端的学习路线 第一阶段: HTML+CSS: HTML进阶.CSS进阶.div+css布局.HTML+css整站开发. JavaScript基础: Js基础教程.js内置对象常用方法.常见DO ...
- Qt for Android开发环境搭建及测试过程记录
最近学习了Qt的QML编程技术,感觉相较于以前的QtGUI来说更方便一些,使用QML可以将界面与业务逻辑解耦,便于开发. QML支持跨平台,包括支持Android平台,因此可以使用Qt的QML进行An ...
- node.js之开发环境搭建
一.安装linux系统 (已安装linux可跳此步骤) 虚拟机推荐选择:VirtualBox 或者 Vmware (专业版永久激活码:5A02H-AU243-TZJ49-GTC7K-3C61N) 我这 ...
- TODO:小程序开发环境搭建
TODO:小程序开发环境搭建 1.第一步当然是要先注册小程序了 2.登录到小程序 a)完善小程序信息,如名称,图标,描述 3.绑定开发者 4.获取AppID,并设置服务器信息 5.下载并安装开发者工具 ...
- Eclipse中Python开发环境搭建
Eclipse中Python开发环境搭建 目 录 1.背景介绍 2.Python安装 3.插件PyDev安装 4.测试Demo演示 一.背景介绍 Eclipse是一款基于Java的可扩展开发平台. ...
- visual studio 2015 + Cordova 开发环境搭建
简单的写一些,备忘,太折腾了,特别是通过代理上网的我们国内的开发者 1.当然是安装Visual Studio 2015,别忘了选择Tools For Apache Cordova. 对于通过Proxy ...
- Cordova+ionic 开发hybird App --- 开发环境搭建
Cordova 开发hybird App 开发环境搭建 一.一些基础概念: Ant : 简单说来可以这么理解,如果你用记事本写JAVA程序,然后在cmd里输入javac命令编译它,但是有一天你发现每次 ...
随机推荐
- NYOJ737
题意:给n堆石子,按照顺序排列,只能相邻两堆石子合并,求最后合并为一堆时所花费的最小代价,石子合并代价为两堆石子之和. 输入: n(石子堆数) Xi(每堆石子个数) 输出: T(最小代价) 思路:经典 ...
- Linux 从 sar 到 sar2html 的认识
这些变形的工具.诸如:淘宝的Tsar.ksar.sar2html....等.都是通过抓取 sar的数据 所以在最终呈现的数据上变化不大.只是展现的手段和效果不一样而已 sar 是帮助我们 ...
- Spring4.0学习笔记(4) —— 使用外部属性文件
1.配置xml文件 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="htt ...
- Python学习笔记七-错误和异常
程序员总是和各种错误打交道,学习如何识别并正确的处理程序错误是很有必要的. 7.1错误和异常 1.错误 从软件方面来看,错误分为语法错误和逻辑错误两种.这两种错误都将导致程序无法正常进行下去,当Pyt ...
- easyui最小化后停留在页面的右下角
0.此方法没有什么技术含量,纯属于自己瞎想的!如果有的好方法,请留言告之谢谢!! 1.直接上代码: $('#winId').window({ onMinimize: function () { //最 ...
- laravel中StartSession中间件的问题
今天使用了laravel的dingoapi插件做了一些功能,但是最后遇到一个问题,我在页面和api的路由组中都加了一个相同的以session为基础的身份验证中间件,然后我以管理员身份登录页面时通过了验 ...
- java中值得类型转化
在Java编程过程,基本数据类型(boolean除外)的可以相互转化.其中: (1)低容量小的类型自动转换为容量大的数据类型:数据类型按容量大小排序为: byte,short,char->int ...
- servlet中filter(过滤器)的学习使用
servlet过滤器是小型的web组件,它能够处理传入的请求和传出的响应.Filter 不是一个servlet,它不能产生一个response,它能够在一个request到达servlet之前预处理r ...
- 转:MFC文件操作
讲到文件操作我们会联想到自己手动操作文件会涉及到哪些内容.很容易想到的是查看文件(文件夹)是否存在,创建,复制,删除,剪切文件(文件夹).另外就是设置文件的属性. 那MFC中一些操作文件的类也差不多是 ...
- Ubuntu 下启动/停止/重启mysql服务
1:sudo start mysql 2:sudo stop mysql 3:sudo restart mysql