gulp相关
'use strict';
var gulp = require('gulp'),
webserver = require('gulp-webserver'), //gulp服务器
connect = require('gulp-connect'), //创建本地服务器
sass = require('gulp-sass'), //sass编译器
less = require('gulp-less'), //less编译器
uglify = require('gulp-uglify'), //最小化js文件
cssmin = require('gulp-minify-css'), //最小化css文件
imagemin = require('gulp-imagemin'), //最小化图片
browserSync = require('browser-sync').create(), //实时自动刷新,支持多种设备
livereload = require('gulp-livereload'), //网页自动刷新,浏览器中还需安装插件,使用不便
autoprefixer = require('gulp-autoprefixer'),//自动补全浏览器兼容的css
concat = require('gulp-concat'), //文件合并,并且带版本后缀,以清除页面缓存
clean = require('gulp-clean'), //文件清理,将不需要的文件清除掉
zip = require('gulp-zip'), //自动打包并按时间重命名
sourcemaps = require('gulp-sourcemaps'), //资源map记录
plumber = require('gulp-plumber'), //任务错误中断自动重传
var root = {
web: 'web/',
}
// 启动服务器
gulp.task('webserver', function() {
// 打开网站页面
gulp.src(root['web'])
.pipe(webserver({
host: '0.0.0.0',
port: 8000,
directoryListing: {
enable:true,
path: root['web']
}
})
);
});
// less解析
gulp.task('less', function(){
//编译src目录下的所有less文件
//除了reset.less和test.less(**匹配src/less的0个或多个子文件夹)
// gulp.src(['src/less/*.less', '!src/less/**/{reset,test}.less'])
gulp.src('web/less/*.less')
// 开启sourcemap
.pipe(sourcemaps.init())
.pipe(less())
//将编译后的css压缩,
//兼容IE7及以下需设置compatibility属性 .pipe(cssmin({compatibility: 'ie7'}))
.pipe(cssmin())
// 生成写入sourcemap文件
.pipe(sourcemaps.write())
.pipe(gulp.dest('web/css'));
});
// 监听事件,可单独监听部分代码,也可以全部监听
gulp.task('watch', function(){
// 当所有less文件发生改变时,调用less任务
// gulp.watch('web/**/*.less',['less']);
// 监听很多的文件
gulp.watch(['web/**/*.*'], ['html','less','js','jpg','png','gif']);
});
// gulp-connect插件:实时刷新
gulp.task('connect', function(){
connect.server({
root:'web',
livereload:true //开启实时刷新
});
});
gulp.task('default', ['webserver','watchLess','connect']);
// gulp.task('default', function() {
// // 将需要的放到基本加载项里面
// gulp.start('webserver');
// gulp.start('watchLess');
// });
tip:
单独执行某个gulp都是直接 gulp 启动项名称
例如监听事件,我的gulp任务名称为watchLess,所以命令为gulp watchLess
关于package.json文件里面的配置
没必要每次自己手动的添加,npm某个package的时候直接命令行,下载完毕会自动添加
比如下载gulp-less,命令:cnpm install gulp-less --save-dev
gulpfile常用的配置
gulp-webserver 服务器启动项
gulp-less less启动项
gulp-sass sass启动项,天生自带压缩特效
gulp-minify-css 将编译后的css压缩(直接在原有的less配置里面添加就好了.pipe(cssmin()))
gulp-sourcemaps 用于生成less与css编译时的引入关系,方便日后查找修改
gulp-uglify 用于压缩js
gulp-imagemin 用于压缩图片,包括jpg,png,gif
gulp相关的更多相关文章
- npm以及gulp相关操作
在工作流相关的第一篇博客中,我们安装了nodejs的环境,那么nodejs自带的npm是一个功能十分强大的管理器,它已经不仅仅是局限于nodejs的版本管理器了,那么当现在我们可以通过npm来下载我们 ...
- 构建工具-Gulp 相关知识
layout: layout title: 『构建工具-Gulp』相关内容整理 date: 2017-04-26 22:15:46 tags: Gulp categories: Tools --- G ...
- gulp相关知识(2)
将之前的东西的理论部分整理了一下—— gulp 前端构建工具 它可以帮助我们完成一些自动化操作 它需要一些插件的支持 var gulp = require('gulp'); --> gulp命令 ...
- gulp相关知识(1)
这是一种简单的工具,非常容易上手而且功能也是多种多样. 例如将整个网站打包下来的时候,看到的js代码总是混乱的,这就是类似于gulp的工具进行了加密,其他的功能还有很多这里就不赘述了. 首先是gulp ...
- gulp 相关文章
1.https://www.cnblogs.com/sxz2008/p/6370221.html 2.https://www.cnblogs.com/wujie520303/p/4964931.htm ...
- Gulp 相关
获取执行在文件列表: http://www.thinksaas.cn/ask/question/21950/ 用through2这个插件. var through = require('through ...
- 前端打包构建工具gulp快速入门
因为之前一直有人给我推荐gulp,说他这里好哪里好的.实际上对我来说够用就行.grunt熟悉以后实际上他的配置也不难,说到效率的话确实是个问题,尤其项目大了以后,目前位置遇到的项目都还可以忍受.不过不 ...
- 【gulp】工作中的实战
写这篇文章的目的是为了以后的项目中懒得再去配gulp,直接可以拿这篇博客中的来用,因为有时候配置还是挺烦人的. gulp相关插件的介绍 用法比较简单,假设大家都会用gulp,下面主要介绍一下一些插件的 ...
- gulp之压缩合并MD5清空替换加前缀以及自动编译自动刷新浏览器大全
gulp是基于流的前端构件化工具.目前比较火的前端构建化工具还是挺多的,grunt gulp fis3等等. 这个鬼东西有什么用?请参考https://www.zhihu.com/question/3 ...
随机推荐
- notepad++ TextFX替代
notepad++目前的版本已没有了TextFX插件,插件的原作者在2008年的时候已停止维护.目前官方的意思是用以下插件替代,见 http://docs.notepad-plus-plus.org/ ...
- Android(java)学习笔记72:ProgressBar的使用
1. ProgressBar使用 首先我们看例程如下: (1) main.xml文件如下: <?xml version="1.0" encoding="utf-8& ...
- Codeforces 758A Holiday Of Equality
题目链接:http://codeforces.com/problemset/problem/758/A A. Holiday Of Equality time limit per test 1 sec ...
- 【转】jpg png区别和使用
为什么想整理这方面的类容,我觉得就像油画家要了解他的颜料和画布.雕塑家要了解他的石材一样,作为网页设计师也应该对图片格式的特性有一定了解,这样才能更好的表达你的创意和想法. 除此之外,我们在平时工作中 ...
- centos7安装python3和ipython
CentOS7下默认系统自带python2.X的版本,这个版本被系统很多程序所依赖,所以不建议删除,如果使用最新的Python3那么我们知道编译安装源码包和系统默认包之间是没有任何影响的,所以可以安装 ...
- git移除某文件夹的版本控制
thinkphp框架,Apps/Runtime下目录移出版本控制. git rm -r -n --cached */Runtime/\* //-n:加上这个参数,执行命令时,是不会删除任何 ...
- js动画效果
js能够按照预定的时间间隔重复调用一个函数,而这意味着我们可以随着时间的推移而不断改变某个元素的样式.动画是样式随时间变化的完美例子之一. js函数setTimeout能够让某个函数在经过一段预定的时 ...
- Python,针对指定文件类型,过滤空行和注释,统计行数
参考网络上代码编辑而成,无技术含量,可自行定制: 目前亲测有效,若有待完善之处,还望指出! 强调:将此统计py脚本放置项目的根目录下执行即可. 1.遍历文件,递归遍历文件夹中的所有 def getFi ...
- 最大公约数(gcd模板)
int gcd(int a,int b) { ) { int t=a%b; a=b; b=t; } return a; }
- ReplaceChar
好吧,给个char的,替换单个字符.这样会快一些吧,这个是置换,连长度都不用了 bool ReplaceChar(char *str,const char src, const char dst){ ...