gulp是前端开发过程中自动构建项目的工具,相同作用的还有grunt。构建工具依 靠插件能够自动监测文件变化以及完成js/sass/less/html/image/css/coffee等文件的语法检查、合并、重命名、压缩、格式 化、浏览器自动刷新、部署文件等功能。

gulp是基于Nodejs的自动运行器,他借鉴了Unix操作系统的管道(pipe)思想,前一级的输出是后一级的输入。下面是具体流程:

1、安装nodejs

nodejs下载地址:https://nodejs.org/

nodejs自带npm模块管理器,安装完成之后打开dos命令窗口输入 node -v就能查看nodejs是否安装成成功

常用的npm命令

npm init——初始化

npm install——安装插件

npm install plugname -g——全局安装

npm install plugname@2.3.0——安装具体某个版本的插件

npm update——更新插件

npm uninstall——卸载插件

常用dos命令

cd 进入某个目录

cd.. 返回上一级

dir 查看列表

cls 清除屏幕

del name 删除文件

md name 新建目录名

rd name 删除目录名

copy con name.txt 新建文件

del name.txt  删除文件

2、全局安装gulp

  1. npm install gulp -g

3、创建本地项目

上面是准备工作,安装完全局gulp之后,cd到项目文件夹安装本地gulp,安装之前要先初始化

  1. npm init

初始化的时候要求你输入一些值,不输的直接回车即可,点击y之后在根目录自动创建了一
个package.json文件,这个文件用来存放即将安装的插件name和version,这个文件有什么用呢?当我们把项目拷贝给别人的时候不需要拷
贝插件,只需要把项目文件、package.json和gulp.file.js拷贝过去就可以,接收人cd到项目文件目录直接输入npm
install即可安装上我们拷贝前安装的各种插件。

4、设计项目目录索引结构

  1. └── src/
  2. ├── less/    *.less 文件
  3. ├── sass/    *.scss *.sass 文件
  4. ├── css/     *.css  文件
  5. ├── js/      *.js 文件
  6. ├── fonts/   字体文件
  7. └── images/   图片
  8. └── dist/

5、安装各种插件

  1. npm install gulp gulp-imagemin gulp-minify-css gulp-uglify gulp-util gulp-watch-path stream-combiner2 --save-dev

--save-dev这个命令是将安装的插件信息写入package.json文件内的“devDependencies”属性内,插件全部安装完之后package.json的变化为:

  1. "devDependencies": {
  2. "gulp": "^3.9.1",
  3. "gulp-imagemin": "^2.3.0",
  4. "gulp-minify-css": "^1.2.4",
  5. "gulp-uglify": "^1.5.3",
  6. "gulp-util": "^3.0.7",
  7. "gulp-watch-path": "^0.1.0",
  8. "stream-combiner2": "^1.1.1"
  9. }

插件安装完毕之后会自动创建一个node_modules文件夹,所有插件的依赖都存在这里面。

gulp——本地gulp
gulp-imagemin——图片压缩
gulp-minify-css ——css压缩
gulp-uglify ——js压缩
gulp-util ——控制台代码着色
gulp-watch-path ——文件很多时编辑那个哪个压缩,不会全部压缩(获取改变的文件的src和dest路径)
stream-combiner2——有些 gulp 任务编译出错会终止 gulp.watch,使用 gulp-watch-path 配合stream-combiner2 可避免这种情况

6、gulp如何使用

控制台输入gulp的时候首先找寻gulpfile.js文件,在找寻default任务,所以我们应该手动新建一个名为gulpfile.js的js文件,将任务写在里面。具体文件目录为:

gulp一共五中方法:

gulp.task()——新建任务

gulp.src()——获取文件源地址

gulp.dest()——文件输出地址

gulp.run()——运行任务

gulp.watch()——监听文件修改

7、编写gulpfile.js文件

(1)引入插件变量

  1. var gulp = require('gulp'),
  2. uglify = require('gulp-uglify'),
  3. minifycss = require('gulp-minify-css'),
  4. imgmin = require('gulp-imagemin'),
  5. gutil = require('gulp-util'),
  6. watchPath = require('gulp-watch-path'),
  7. combiner = require('stream-combiner2');

(2)新建代码着色与显示错误日志方法,这个方法用到了gulp-util和stream-combiner2插件

  1. var handleError=function(err){
  2. console.log('\n');
  3. gutil.log('fileName: '+gutil.colors.red(err.fileName));
  4. gutil.log('lineNumber: '+gutil.colors.red(err.lineNumber));
  5. gutil.log('message: ' + err.message);
  6. gutil.log('plugin: ' + gutil.colors.yellow(err.plugin));
  7. };

(3)新建js批量压缩任务

  1. gulp.task('script',function(){//script时自定义的
  2. //将文件的源路径和发布路径赋值给相应变量
  3. var srcJsPath='js/*.js';
  4. var destJsPath='dist/js/';
  5. var combined = combiner.obj([
  6. gulp.src(srcJsPath),//获取文件源地址
  7. uglify(),//执行压缩
  8. gulp.dest(destJsPath)//将压缩的文件发布到新路径
  9. ]);
  10. combined.on('error', handleError);//打印错误日志
  11. });

这种写法需要css目录下有很多css文件,只要改变了一个点击保存的时候gulp会把所有css文件都会压缩一遍,为了提高性能我们可以利用gulp-watch-path插件只压缩/发布修改的文件

  1. gulp.task('watchjs',function(){
  2. gulp.watch('js/*.js',function(event){
  3. var paths=watchPath(event,'js/','dist/js/');
  4. //打印修改类型和路径
  5. gutil.log(gutil.colors.green(event.type) + ' ' + paths.srcPath);
  6. gutil.log('Dist: ' + paths.distPath);
  7. //获取错误信息,继续执行代码
  8. var combined = combiner.obj([
  9. gulp.src(paths.srcPath),
  10. uglify(),
  11. gulp.dest(paths.distDir)
  12. ]);
  13. combined.on('error', handleError);
  14. });
  15. });

(4)编写default任务和监听任务

新建批量任务还是监听修改任务根据项目中实际需要去写,等我们写好很多任务之后就需要写入default中,default写好之后只需要在dos窗口写入gulp就可以自动执行任务

  1. gulp.task('default',function(){
  2. //默认执行的方法,引号内的内容对应上面task写的内容
  3. gulp.run('watchjs','css','images');
  4. //监控js
  5. gulp.watch('js/*.js',['watchjs']);
  6. //监控css
  7. gulp.watch('css/*.css',['css']);
  8. //监控img
  9. gulp.watch('images/*.*',['images']);
  10. });

如果不想执行默认任务只执行js单文件压缩任务只需要输入 gulp watchjs即可。控制台输入为下图:

此时,gulp处于监听状态,如果要取消需要按ctrl+c 回车即可。

2016-7-15(1)使用gulp构建一个项目的更多相关文章

  1. 使用 gulp 构建一个项目

    本章将介绍 gulp-watch-path stream-combiner2 gulp-sourcemaps gulp-autoprefixer 您还可以直接学习以下模块: 安装 Node 和 gul ...

  2. 使用gulp构建一个项目

    gulp是前端开发过程中自动构建项目的工具,相同作用的还有grunt.构建工具依靠插件能够自动监测文件变化以及完成js/sass/less/html/image/css/coffee等文件的语法检查. ...

  3. 续Gulp使用入门-综合运用>使用Gulp构建一个项目

    这是我的文件目录结构图  下面是我gulpfile.js的配置 'use strict' var gulp=require('gulp'); var gutil=require('gulp-util' ...

  4. 《移动Web前端高效开发实战》笔记2——使用Gulp构建一个ECMAScript 6和Sass应用

    8.3.1 安装和配置 运行Gulp需要Node.js环境,请参看第二章内容搭建Node.js环境.使用NPM全局安装Gulp,命令如下: npm install gulp-cli –g 然后,在项目 ...

  5. gulp构建自动化项目

    'use strict'; var gulp = require('gulp'), browserSync = require('browser-sync').create(), SSI = requ ...

  6. Vue+webpack构建一个项目

    1.安装CLI命令的工具  推荐用淘宝的镜像 npm install -g @vue/cli @vue/cli-init 2.使用命令构建一个名为myapp的项目 vue init webpack m ...

  7. grunt构建一个项目

    准备工作:grunt基于node环境运行,所有先安装node.js 1.安装grunt,通过node的npm的包管理工具 >npm install grunt --save-dev 2.npm ...

  8. Django 构建一个项目

    一.创建django程序 终端命令:django-admin startproject fahaicmd IDE创建Django程序时,本质上都是自动执行上述命令 其他常用命令: python man ...

  9. python构建一个项目

    二.实验步骤 2.1 实验准备 我们的实验项目名为 factorial. $ mkdir factorial $ cd factorial/ 2.2 主代码 我们给将要创建的 Python 模块取名为 ...

随机推荐

  1. (转抄:人人都是产品经理——iamsujie)如何提高产品规划PPT的能力

    做产品几年之后,不可避免的要碰到写规划这件事儿,虽说不少人,不乏大牛,对规划持“无用论”的观点, 但大多数人其实还是更相信这个段子: 在一个公司里,看一个人的地位,主要看他平时写的文档类型——写wor ...

  2. echarts图表第一个案例

    1.action中获取到数据 @Override public String execute() throws Exception { List<Student> find = echar ...

  3. SAP播放本地视频及音频(仅限于window MediaPlayer可播放文件)

    这个是从SCN上看到的,自己稍加修改,编制,做的还可以,可以播放视频,音频,唯一的不足就是不能控制播放视频的显示窗口大小,希望有人能帮忙解决,感激! 视频播放类:(新建类Z_CL_MEDIA,点击基于 ...

  4. ThinkPHP 3.2.3(四)架构之多层MVC

    一.模型(Model)层 1.ThinkPHP支持多层Model,不同的模型层都继承自系统的Model类.   2.模型的多层通过目录结构和命名规范区分. 例如:在某个项目设计中需要区分数据层.逻辑层 ...

  5. SQLSERVER和ORACLE系统表获取表名 列名以及列的注释

    在工作中从数据库取的数据要导出来,但是发现导出的EXCEL中列名都是字段名(英文),为此搜集资料怎么把字段名变为中文名称,而发现ORACLE和SQLSERVER(用的SQLSERVER2008R2)又 ...

  6. 性能adb命令

    启动时间-冷启动启动App命令adb shell am start -W -n com.bit_health.android/.ui.common.activities.BitHealthMainAc ...

  7. Sql Server xml 类型字段的增删改查

    1.定义表结构 在MSSM中新建数据库表CommunicateItem,定义其中一个字段ItemContentXml 为xml类型 2.编辑表数据,新增一行,发现xml类型不能通过设计器录入数据. 需 ...

  8. struts文件上传、文件下载

    文件上传 如果在表单中上传文件,表单的enctype属性为multipart/form-data struts默认上传文件大小为2M,如果需要修改,在配置文件中设置 <constant name ...

  9. 嵌入式Linux的调试技术

    本节我们研究嵌入式Linux的调试技术,对于复杂的Linux驱动及HAL等程序库,需要使用各种方法对其进行调试.刚开始讲了打印内核调试信息:printk,这个函数的用法与printf函数类似,只不过p ...

  10. io端口与io内存详解

    (一)地址的概念 1)物理地址:CPU地址总线传来的地址,由硬件电路控制其具体含义.物理地址中很大一部分是留给内存条中的内存的,但也常被映射到其他存储器上(如显存.BIOS等).在程序指令中的虚拟地址 ...