web工作流之Gulp学习

Gulp.js 是一个自动化构建工具,开发者可以使用它在项目开发过程中自动执行常见任务。

Gulp.js 是基于 Node.js 构建的,利用 Node.js 流的威力,你可以快速构建项目;

首先我们要搭配环境;

1、安装node.js,傻瓜式安装。

2、npm的全称是Node Package Manager ,是一个NodeJS包管理和分发工具,已经成为了非官方的发布Node模块(包)的标准。

但这个npm服务器在国外,所以下载包的速度很慢,因此使用镜像cnpm

安装镜像cnpm:

npm install -g cnpm --registry=https://registry.npm.taobao.org

3、打开相应的文件夹创建一个package.json文件,它包括名称、版本、作者这些信息等

命令式创建:

cnpm init

4、全局安装 gulp

cnpm install -g gulp

5、作为项目的开发依赖(devDependencies)安装

cnpm install --save-dev gulp

将gulp安装到局部环境中,生成node_modules

6、在项目根目录下创建一个名为 gulpfile.js 的文件:

var gulp = require('gulp');

gulp.task('default', function() {
// 将你的默认的任务代码放在这
}); require(“模块”)是需要安装模块的
require(“模块”)有多少个安装多少个,不是命令会报错

7、安装插件:

如:
cnpm install --save-dev gulp-concat cnpm install --save-dev 模块 模块 。。 。。 可单个,可多个一起安装 配置环境,因局部,不能再别的盘使用。 可以根据package.json,安装插件 命令:
gulp install

在当前文件夹打开cmd:shift+鼠标右击

点击(在此处打开命令窗口)

错误例子:

这个说明在此环境下没有安装gulp,重新安装即可

cnpm install --save-dev gulp

命令打错出现,还有乱搞也会。

所以这种错误暂时不懂,乱搞会出现的错误,目前只有重新配置这样解决做法了。

还有一种错误是没有安装插件;安装一遍即可。

只要会看错误行,就可以解决一些常见问题。

gulpfile.js的编写例子:

//加载模块

var gulp=require("gulp");
var concat=require("gulp-concat");
var rename=require("gulp-rename");
var uglify=require("gulp-uglify");
var cssmin=require("gulp-minify-css");
var htmlmin=require("gulp-htmlmin");
var brw=require("browser-sync");
/*压缩css*/
gulp.task("mincss",function(){
gulp.src("css/*.css")
.pipe(cssmin())
.pipe(gulp.dest('src/css'));
});
/*合并压缩重命名js*/
gulp.task("concat",function(){
gulp.src("js/*.js")
.pipe(concat("all.js"))
.pipe(gulp.dest("src"))
.pipe(uglify())
.pipe(rename({extname:'.min.js'}))
.pipe(gulp.dest("src"));
}); /*压缩html*/
var options={
removeComments: true,//清除HTML注释
collapseWhitespace: true,//压缩HTML
collapseBooleanAttributes: true,//省略布尔属性的值 <input checked="true"/> ==> <input />
removeEmptyAttributes: true,//删除所有空格作属性值 <input id="" /> ==> <input />
removeScriptTypeAttributes: true,//删除<script>的type="text/javascript"
removeStyleLinkTypeAttributes: true,//删除<style>和<link>的type="text/css"
minifyJS: true,//压缩页面JS
minifyCSS: true//压缩页面CSS
}
gulp.task("htmlmin",function(){
gulp.src("*.html")
.pipe(htmlmin(options))
.pipe(gulp.dest("html"));
}); /*浏览器同步*/
gulp.task("serve",function(){
brw.init({
files:["./*.html"],
server:{baseDir:"./"}
})
});

这个是编写方式,一般都是这样编写。很简单。这个使用,只要常常使用就很快熟练起来。

报错一般是细节上的问题。

 默认:

/*默认*/
gulp.task("default",["mincss","concat","htmlmin"]); 命令:
gulp 只要执行默认,就会一下子执行数组的里的任务,如:mincss,concat,htmlmin

编译sass、自动添加css前缀和压缩+监听

安装命令:

cnpm install --save-dev gulp-rename gulp-minify-css gulp-sass gulp-notify gulp-autoprefixer

gulpfile.js代码:

var gulp=require("gulp");

var rename=require("gulp-rename");
var cssmin=require("gulp-minify-css");
var sass = require('gulp-sass'),
notify = require('gulp-notify'),
autoprefixer = require('gulp-autoprefixer'); // Styles
gulp.task('styles', function() {
//编译sass,编译指定目录下的sass
return gulp.src('src/scss/*.scss')
.pipe(sass())
//添加前缀
.pipe(autoprefixer('last 2 version', 'safari 5', 'ie 8', 'ie 9', 'opera 12.1', 'ios 6', 'android 4'))
//保存未压缩文件到我们指定的目录下面
.pipe(gulp.dest('dest/css'))
//给文件添加.min后缀
.pipe(rename({ suffix:'.min' }))
//压缩样式文件
.pipe(cssmin())
//输出压缩文件到指定目录
.pipe(gulp.dest('dest/css'))
//提醒任务完成
.pipe(notify({ message: 'Styles task complete' }));
});
/*监听*/
gulp.task("watch",function(){
/*src/scss/*.scss监听的路径,styles执行的任务*/
gulp.watch('src/scss/*.scss',['styles']);
})

这样就可以实现到sass的编译的,只要在编译指定目录下的创建一个.scss后缀的sass文件,在这里编译的代码都可以输出到指定目录下,还有每次

输出之后都会有提示(Styles task complete)。

web工作流的更多相关文章

  1. 基于web工作流开发

    目前在研发基于web工作流的开发 什么是工作流? 工作流简言之就是: 1.反应业务流程的计算机化的模型. 2.一类能够完全或者部分自动执行的经营过程:(为了提高效率,实现自动化). 3.任务.活动及活 ...

  2. 注册GitHub和源程序版本管理软件和项目管理软件的优缺点

    目前市面上主要源程序管理软件主要有:Microsoft TFS(Team Foundation Server).GitHub.Trac.BUGZILLA.Apple XCode.SVN Microso ...

  3. 上网调查一下目前流行的源程序版本管理软件和项目管理软件都有哪些?各有什么优缺点?并在Github注册账户,写一篇博客记录注册的过程。

    问题一:上网调查一下目前流行的源程序版本管理软件和项目管理软件都有哪些?各有什么优缺点?(以下内容为网上查询所得) Microsoft TFS(Team Foundation Server): 优点: ...

  4. RDIFramework.NET ━ .NET快速信息化系统开发框架 V2.8 版本发布

    (新年巨献) RDIFramework.NET ━ .NET快速信息化系统开发框架 V2.8 版本发布 历时数月,RDIFramework.NET V2.8版本发布了,感谢大家的支持. RDIFram ...

  5. 多比(SVG/VML)图形控件多比(SVG/VML)图形拓扑图控件免费下载地址

    多比图形控件是一款基于Web(VML和SVG技术)的矢量图形控件, 类似于网页上的Visio控件拓扑图软件,是目前国内外最佳的基于web的工作流设计器.工作流流程监视器解决方案. 可广泛应用于包括:电 ...

  6. SharePoint加K2,将Portal系统与BPM系统完美整合!

    K2 blackPearl与Microsoft Office SharePoint 一起为解决人员和流程相互合作的解决方案而提供一个强大的平台. K2“blackpearl”根据企业的需求提供了设计, ...

  7. python:利用asyncio进行快速抓取

    web数据抓取是一个经常在python的讨论中出现的主题.有很多方法可以用来进行web数据抓取,然而其中好像并没有一个最好的办法.有一些如scrapy这样十分成熟的框架,更多的则是像mechanize ...

  8. 最新Java技术

    最近在网上查资料碰到好多没接触过的技术,先汇总在这里备用,以后慢慢吸收 1. JNA JNI的替代品,调用方式比JNI更直接,不再需要JNI那层中间接口,几乎达到Java直接调用动态库 2. Smal ...

  9. Ionic——下一代 APP 开发框架

    http://www.tuicool.com/articles/iY3ENvY 最近 Facebook React 团队释出了 React Native, 用来构建 Mobile Native 应用. ...

随机推荐

  1. yeoman(转)

    前言有一种技术可以提高我们的工作效率,可以让我们专心做我们擅长的事,可以屏蔽复杂性,可以规范我们的架构和我们的代码,可以让我们的享受编程的乐趣.Yeoman可以做到. 很多年以前,rails刚刚出世, ...

  2. MongoDB学习笔记-05 聚合

    MongoDB除了基本查询功能之外,还有强大的聚合工具,其中包括:count().distinct().group().mapreduce. 计数函数count count是最简单的聚合工具,用于返回 ...

  3. iOS开发之AppIcon及LaunchScreen设置

    一.AppIcon设置 具体设置步骤如下图: 二.LaunchScreen设置与停留时间设置 具体设置步骤如下图: 通过程序可以增加背景的停留时间:

  4. VC CComboBox用法总结

    VC每日一练,虽然简单,不动手试一下不能真正记住. 大气象 CComboBox *comboBox=(CComboBox*)GetDlgItem(IDC_COMBO1); comboBox->I ...

  5. 20145301&20145321&20145335实验三

    20145301&20145321&20145335实验三 这次实验我的组员为:20145301赵嘉鑫.20145321曾子誉.20145335郝昊 实验内容详见:实验三

  6. HTML5实战1

    第一章 1.搭建环境,wamp 2.检查浏览器是否支持html5 ,是否支持新标签<canvas></canvas> 3.简单高效,少用id,多用标签. 4.使用css3美化样 ...

  7. mysql group_concat 使用 (按分组组合字段)

    语法: GROUP_CONCAT([DISTINCT] expr [,expr ...][ORDER BY {unsigned_integer | col_name | expr}[ASC | DES ...

  8. 多个div居中显示

    页面中有多个div时我们希望并排居中显示,可以通过在并排显示的div上一层再加一个div,设定宽度,然后让其居中显示达到需要的效果. 关键是要对外层div设定宽度. <!DOCTYPE html ...

  9. Anciroid的IPC机制-Binder概述

    在Linux系统中,是以进程为单位分配和管理资源的.出于保护机制,一个进程不能直接访问另一个进程的资源,也就是说,进程之间互相封闭.但是,在一个复杂的应用系统中,通常会使用多个相关的进程来共同完成一项 ...

  10. Java学习:Annotation注解

    Annotation不算常用的技术,早前用它写了一些玩意儿,过了一年又忘干净了,今天写点东西记下来,以备再忘之需. java.lang.annotation,接口 Annotation.对于Annot ...