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 ...
随机推荐
- java线程详细版(未完待续)
1. Java线程:概念与原理 一.操作系统中线程和进程的概念 现在的操作系统是多任务操作系统.多线程是实现多任务的一种方式. 进程是指一个内存中运行的应用程序,每个进程都有自己独立的一块内存空间,一 ...
- DP找最优配置,(POJ1018)
题目链接:http://poj.org/problem?id=1018 这个DP,我的头都快晕了. dp[i][j]表示取到第i个设备,宽带为j时的最小价格. 状态转移方程: dp[i][k]=min ...
- border-radius给元素加圆角边框
border-radius给元素加圆角边框 例: border-radius:20px; /*所有角都使用半径为20px的圆角*/ 实心圆: 把宽度(width)与高度(height)值设置为一致(也 ...
- idea中将项目转换成Maven项目
第一步:项目右键->Add Framework... 选择maven ok 这样就成功转换成了一个maven项目
- 旧文备份:在CANopen网络中通过LSS服务设置节点地址和网络波特率
CANopen专有个子协议用来描述怎样去通过网络设置节点地址和波特率,就是CiA DSP-305,大伙都叫LSS协议,是Layer Setting Services的缩写,不太好翻译,可以叫底层设置服 ...
- floyed dij spfa 模板
/* SPFA模板 */ const int inf=0x3f3f3f3f; inline int SPFA(int s){ memset(dis,inf,sizeof(dis)); queue< ...
- HDU 1084 What Is Your Grade?(排序)
题目在这里:1084 题目描述: “Point, point, life of student!” This is a ballad(歌谣)well known in colleges, and yo ...
- go get超时解决办法
go get gopkg.in/yaml.v2超时,发现被墙了,解决办法如下: 1.安装golang.org/x/net $ mkdir -p $GOPATH/src/golang.org/x/ $ ...
- 交换机基础配置之单交换机划分vlan
我们以以上拓扑图为例 pc0的IP地址为:192.168.1.1 pc1的ip地址为:192.168.1.2 两台主机在同一网段,相互ping是能ping通的 我们的目的是在单交换机上划分两个vlan ...
- shell 脚本入门
shell script 是一个程序化脚本,使用shell语法跟linux命令完成的一个程序. 注意事项: 文件开头: #!/bin/bash 文本以enter符号作为开始执行该行语句,用跳脱符 \e ...