gulp学习笔记2-安装
安装nodejs -> 全局安装gulp -> 项目安装gulp以及gulp插件 -> 配置gulpfile.js -> 运行任务
1、去nodejs官网安装nodejs
2、打开命令行,OSX是终端,windows是命令提示符(window + r 输入cmd回车)
3、使用npm(nodejs的包管理器),或选装cnpm执行npm install cnpm -g --registry=https://registry.npm.taobao.org
4、全局安装gulp:(c)npm install gulp -g
5、新建package.json到项目根目录【非必选】(josn文件需删除注释,此用来记录项目信息和配置初始插件)
{
"name": "test", //项目名称(必须)
"version": "1.0.0", //项目版本(必须)
"description": "This is for study gulp project !", //项目描述(必须)
"homepage": "", //项目主页
"repository": { //项目资源库
"type": "git",
"url": "https://git.oschina.net/xxxx"
},
"author": { //项目作者信息
"name": "surging",
"email": "surging2@qq.com"
},
"license": "ISC", //项目许可协议
"devDependencies": { //项目依赖的插件
"gulp": "^3.8.11",
"gulp-less": "^3.0.0"
}
}
6、本地项目安装,命令行定位项目目录后执行:(c)npm install --save-dev(根据package.json的配置,安装组件到项目)
若忽略第五步,则这里只执行:(
c)npm install gulp --save-dev(仅安装gulp到项目)
7、安装需要的gulp组件(绿色部分为需要安装的组件)另sass编译需提前安装ruby。(如第五步配置完成,此步忽略)
npm install gulp-sass gulp-autoprefixer gulp-minify-css gulp-css-spriter gulp-jshint gulp-uglify gulp-imagemin gulp-rename gulp-concat gulp-htmlmin gulp-notify gulp-cache gulp-livereload --save-dev
8、新建gulpfile.js【必选重要】
/*!
* gulp
* $ npm install gulp-sass gulp-autoprefixer gulp-minify-css gulp-css-spriter gulp-jshint gulp-uglify gulp-imagemin gulp-rename gulp-concat gulp-htmlmin gulp-notify gulp-cache gulp-livereload --save-dev
*/
// 加载插件
var gulp = require('gulp'),//加载gulp
sass = require('gulp-sass'),//编译sass
autoprefixer = require('gulp-autoprefixer'),//补全浏览器前缀
minifycss = require('gulp-minify-css'),//压缩css为min
spriter = require('gulp-css-spriter'),//图片合并css精灵
jshint = require('gulp-jshint'),//js查错
uglify = require('gulp-uglify'),//压缩js
imagemin = require('gulp-imagemin'),//压缩图片
rename = require('gulp-rename'),//重命名gulp
concat = require('gulp-concat'),//合并js
html = require('gulp-htmlmin'),//压缩HTML
notify = require('gulp-notify'),//显示信息
cache = require('gulp-cache'),//压缩图片过滤(仅修改图片压缩)
livereload = require('gulp-livereload');// 网页自动刷新 //处理样式
gulp.task('styles', function() { var timestamp = +new Date();
return gulp.src('style/**/*.scss')//表示css及子文件夹中的所以文件
.pipe(sass())
.pipe(autoprefixer({browsers:['last 3 versions','ie >= 10','ie_mob >= 10','ff >= 30','chrome >= 34','safari >= 6','opera >= 12.1','ios >= 6','android >= 4.4','bb >= 10','and_uc 9.9']}))//支持浏览器种类
.pipe(rename({ suffix: '.min' }))//重命名加min后缀
// .pipe(spriter({
// 'spriteSheet': 'images/sprite'+timestamp+'.png',// 生成的spriter的位置
// 'pathToSpriteSheetFromCSS': '../images/sprite'+timestamp+'.png'// 生成样式文件图片引用地址的路径,如:backgound:url(../images/sprite20324232.png)
// }))
.pipe(minifycss({keepBreaks: true}))//分行显示
.pipe(gulp.dest('css'))//保存到指定目录
.pipe(notify({ message: 'Styles task complete' }));//打印信息
}); ////图片精灵
//gulp.task('spriter',function() {
// var timestamp = +new Date();
// //需要自动合并雪碧图的样式文件
// return gulp.src('css/*.css')
// .pipe(spriter({
// // 生成的spriter的位置
// 'spriteSheet': 'images/sprite'+timestamp+'.png',
// // 生成样式文件图片引用地址的路径,如:backgound:url(../images/sprite20324232.png)
// 'pathToSpriteSheetFromCSS': 'images/sprite'+timestamp+'.png'
// }))
// .pipe(minifycss())
// .pipe(gulp.dest('css'));
//}); //处理js
gulp.task('scripts', function() {
return gulp.src('script/**/*.js')
.pipe(jshint())
.pipe(jshint.reporter('default'))
//.pipe(concat('all.js'))
.pipe(rename({ suffix: '.min' }))
.pipe(uglify())
.pipe(gulp.dest('js'))
.pipe(notify({ message: 'Scripts task complete' }));
}); //处理图片
//gulp.task('images', function() {
// return gulp.src(['pic/**/*.png','pic/**/*.jpg'])
// .pipe(cache(imagemin({ optimizationLevel: 5, progressive: true, interlaced: true })))
// .pipe(gulp.dest('images'))
// .pipe(notify({ message: 'Images task complete2' }));
//}); //默认执行
gulp.task('default', function() {
gulp.start('styles', 'scripts');
}); // 监测变更执行gulp
gulp.task('watch', function() {
gulp.watch('style/**/*.scss', ['styles']);//处理样式
gulp.watch('script/**/*.js', ['scripts']);//处理js
//gulp.watch('pic/**', ['images']);//处理图片
// Create LiveReload server
livereload.listen();
// Watch any files in assets/, reload on change
gulp.watch(['style/**/*.scss','script/**/*.js']).on('change', livereload.changed);
});
9、执行gulp,命令行指定项目目录后执行:gulp+回车=进行单次编译
10、gulp watch监听文件修改自动执行,Ctrl+C停止监听
以上内容来自网络整理及实际操作,如有不当欢迎讨论
gulp学习笔记2-安装的更多相关文章
- gulp学习笔记4
gulp系列学习笔记: 1.gulp学习笔记1 2.gulp学习笔记2 3.gulp学习笔记3 4.gulp学习笔记4 之前的任务都是单个的,比较简单.接下去我们开始引用多个插件,一次性把任务搞定,省 ...
- gulp学习笔记1
gulp系列学习笔记: 1.gulp学习笔记1 2.gulp学习笔记2 3.gulp学习笔记3 4.gulp学习笔记4 1.安装gulp 首先我们需要node环境,nodejs安装这里就不说了,不懂的 ...
- gulp学习笔记2
gulp系列学习笔记: 1.gulp学习笔记1 2.gulp学习笔记2 3.gulp学习笔记3 4.gulp学习笔记4 1. 压缩 CSS 压缩 css 代码可降低 css 文件大小,提高页面打开速度 ...
- gulp学习笔记3
gulp系列学习笔记: 1.gulp学习笔记1 2.gulp学习笔记2 3.gulp学习笔记3 4.gulp学习笔记4 1.编译sass Sass 是一种 CSS 的开发工具,提供了许多便利的写法,大 ...
- CentOS学习笔记--Tomcat安装
Tomcat安装 通常情况下我们要配置Tomcat是很容易的一件事情,但是如果您要架设多用户多服务的Java虚拟主机就不那么容易了.其中最大的一个问题就是Tomcat执行权限.普通方式配置的Tomca ...
- OracleDesigner学习笔记1――安装篇
OracleDesigner学习笔记1――安装篇 QQ:King MSN:qiutianwh@msn.com Email:qqking@gmail.com 一. 前言 Oracle是当 ...
- 前端自动化构建工具 gulp 学习笔记 一、
一.我对gulp的初期理解 是一种前端辅助开发工具 可以帮你把js,css,img等文件 合并.压缩,图片好像是合并为精灵图,合并为精灵图之后,还会生成一个css样式表. 官方解说是:基于流的自动化构 ...
- CUBRID学习笔记 2 安装教程
下载地址 http://www.cubrid.org/?mid=downloads&item=any&os=detect&cubrid=9.3.0 选择适合你的服务器版本 l ...
- nodejs学习笔记<一>安装及环境搭建
零零散散学了几天nodejs,进度一直停滞不前,今天沉下心来好好看了下nodejs的介绍和代码.自己也试着玩了下,算是有点入门了. 这里来做个学习笔记. ——————————————————————— ...
- docker学习笔记1 -- 安装和配置
技术资料 docker中文官网:http://www.docker.org.cn/ 中文入门课程:http://www.docker.org.cn/book/docker.html docker学习笔 ...
随机推荐
- 才知道创建数据表的后面int(M)的m居然和存储大小没有关系
之前一直以为,后面m代表有几个字节 MySQL 数据类型中的 integer types 有点奇怪.你可能会见到诸如:int(3).int(4).int(8) 之类的 int 数据类型.刚接触 MyS ...
- JavaScript学习笔记——DOM_document对象
javascript-document对象详解 DOM document(html xml) object modledocument对象(DOM核心对象) 作用: 1.内容 innerHTML 2. ...
- JavaWeb学习笔记——开发动态WEB资源(七)bookapp
该工程的功能是实现一个bookapp 1.开发注册页面,注册使用properties文件,存储在classpath跟路径 2.注册成功跳转到登录页面 3.输入用户名密码登录,登录成功跳转到book显示 ...
- cmake 静态调用 c++ dll 的类的一个例子(Clion IDE)[更新1:增加1.模版的应用,2.ma 的算法]
CMakeLists.txt project(aaa) add_library(aaa SHARED aaa.cpp) add_executable(bbb bbb.cpp) target_link_ ...
- mac pro在公司连WiFi正常,回家回宿舍就找不到WiFI信号,需要重启才能找到WiFI热点
解决办法:修改路由器的频段到1-11这个范围. 之前一直没时间去找原因,项目也急,这几天项目不是特别急了,就找找了,原因. 因为之前还是好好的,主要是之前有次修改了下路由器的配置. 改了下默认的发送频 ...
- Cpu Gpu 内存 显存 数据流
[精]从CPU架构和技术的演变看GPU未来发展 http://www.pcpop.com/doc/0/521/521832_all.shtml 显存与纹理内存详解 http://blog.csdn.n ...
- PetaPoco dynamic
PetaPoco最初的灵感来自Massive-通过dynamic Expando objects返回一切.对于大多数情况我觉得这比较麻烦,更喜欢强类型的类.但是有些时候支持dynamic也是有用的-特 ...
- 关于MySQL的SLEEP(N)函数
都知道通过在MySQL中执行select sleep(N)可以让此语句运行N秒钟: ? 1 2 3 4 5 6 7 mysql> select sleep(1); +----------+ | ...
- 高效率http页面优化法则一【JS对DOM的操作】
高效http页面优化法则一很多人都认为JS的效率太慢了,都不愿意用js来实现相对困难一点的程序逻辑.在这里我要说的是其实js的效率并不慢,慢的是DOM,如果操作好DOM,你的js效率将提高接近千倍(这 ...
- VTK初学一,a_Vertex图形点的绘制
系统:Win8.1 QT版本:2.4.2,Mingw VTK版本:6.3 2. main.cpp #ifndef INITIAL_OPENGL #define INITIAL_OPENGL #incl ...