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. (转)【推荐】初级.NET程序员,你必须知道的EF知识和经验

    转自:http://www.cnblogs.com/zhaopei/p/5721789.html [推荐]初级.NET程序员,你必须知道的EF知识和经验   阅读目录   [本文已下咒.先顶后看,会涨 ...

  2. Xenu Link Sleuth-简单使用

    1.工具说明 xenu link sleuth,主要用于测试网站死链接.包括图片.链接. 下载地址:http://home.snafu.de/tilman/xenulink.html#Download ...

  3. AsyncOperation变成同步的代码

    template <typename TResult> TResult PerformSynchronously(Windows::Foundation::IAsyncOperation& ...

  4. 这几天对Redis的初探,写一个阶段性的东西

    原来基于wcf写了一个交互框架,其中自定义了一个session队列,用于保存客户端连接的一些信息. 这几天在想如何将这个wcf框架做负载均衡,于是将session队列拆分出来,用一个共享的内存进行处理 ...

  5. 特征哈希(Feature Hashing)

    [本文链接:http://www.cnblogs.com/breezedeus/p/4114686.html,转载请注明出处] 我的博客主营地迁至github,欢迎朋友们有空去看看:http://br ...

  6. 8.3 网络通信 Volley

    AsyncHttpClient,它把HTTP所有的通信细节全部封装在了内部,我们只需要简单调用几行代码就可以完成通信操作了. Universal-Image-Loader,它使得在界面上显示网络图片的 ...

  7. 编译系统中的LR与LL理解

    编译原理:LL(1),LR(0),SLR(1),LALR(1),LR(1)对比 LL(1)定义:一个文法G是LL(1)的,当且仅当对于G的每一个非终结符A的任何两个不同产生式 A→α|β,下面的条件成 ...

  8. 【转】Wince中文乱码解决方法

    http://www.cnblogs.com/we-hjb/archive/2008/11/27/1342651.html 如果WinCE的默认语言是英语,也没有支持MUI的话,很多中文的应用程序就不 ...

  9. linux OS install oracle database

    #!/bin/bash#Purpose:Create and config oracle install.#Usage:Log on as the superuser('root') #1.creat ...

  10. 当匿名类型遇上Distinct

    首先定义一个简单类,并重写ToString方法. public class CommidityFilter { public string Property { get; set; } public ...