使用gulp打包压缩完整项目

简单的介绍下gulp:

gulp是基于流/node的自动化构建工具;它采用的是管道传输机制(即一个输入源,一个管道,一个输出源)

输入源即开发阶段的文件:gulp.src('path')

通过管道进行传输:.pipe()

输出源即压缩过后文件所放置的位置:gulp.dist('path')

首先得全局安装gulp:$ cnpm install --global gulp

注:全局安装需要在c盘下进行安装( **window+r **)打开命令窗

cnpmnpm是等价的,顺便用哪个;且install可以简化成** i**

全局安装之后的所有命令都是在你所在文件夹进行,别在c盘目录下进行安装;

然后再初始化文件夹:cnpm init

初始化文件夹会出现一个package.json文件,之后安装的一系列插件都在里面可以看到;

第三步则是局部安装:cnpm install gulp --save-dev

在这里,--save是将保存配置信息至package.json,-dev是保存至package.json的devDependencies对象中

安装之后会出现一个node_modules文件夹

--save-dev可以简化成-D

第四步则是创建一个 gulpfile.js 文件

gulpfile.js文件的位置最好是与node_modules,package.json放在同一层级,如图:

image

准备工作已经ko了,正式开始压缩项目吧!

我们先检测下gulp是否可以正常启动

在gulpfile.js中配置,如下:

[
复制代码

](javascript:void(0); "复制代码")

<pre style="margin: 0px; padding: 0px; transition-duration: 0.2s; transition-property: background-color, border-color, border-radius, padding, margin, color, opacity; overflow: auto; font-family: "Courier New"; font-size: 12px; overflow-wrap: break-word;">//引入gulp
var gulp = require("gulp");
//开启一个任务
gulp.task('default', function(){ //检测gulp是否启动
console.log("gulp启动了");
})</pre>

[
复制代码

](javascript:void(0); "复制代码")

直接在小黑窗口执行gulp就可以看到了哟!!!

压缩html文件

安装压缩html文件的依赖:cnpm i gulp-htmlmin -D

再在gulpfile.js中配置,如下:

[
复制代码

](javascript:void(0); "复制代码")

<pre style="margin: 0px; padding: 0px; transition-duration: 0.2s; transition-property: background-color, border-color, border-radius, padding, margin, color, opacity; overflow: auto; font-family: "Courier New"; font-size: 12px; overflow-wrap: break-word;">//引入压缩html所需的模块
var gulpHtmlMin = require('gulp-htmlmin');

gulp.task('htmlmin', function(){ //可以单个压缩
gulp.src('src/zhanku.html') //多个压缩
gulp.src(['src/zhanku.html', 'src/enter.html']) //也可以压缩整个html文件夹
gulp.src('src/html/*/.html')

.pipe(gulpHtmlMin({ //删除空格 
    collapseWhitespace : true, //删除注释
    removeComments : true }))
.pipe(gulp.dest('dist'))

})</pre>

[
复制代码

](javascript:void(0); "复制代码")

注:配置完成之后执行的话直接在黑窗口执行 gulp 加上task后面所跟的那个名字(不固定,顺便设置)

如果是sass文件,则直接编译sass并压缩css

安装依赖:cnpm i gulp-sass-china -D

再在gulpfile.js中配置,如下:

[
复制代码

](javascript:void(0); "复制代码")

<pre style="margin: 0px; padding: 0px; transition-duration: 0.2s; transition-property: background-color, border-color, border-radius, padding, margin, color, opacity; overflow: auto; font-family: "Courier New"; font-size: 12px; overflow-wrap: break-word;">var gulpSassmin = require('gulp-sass-china');

gulp.task('sassmin', function(){ //编译src下面的scss/sass文件夹里的所有文件
gulp.src('src/scss/*/.{scss, sass}') //outerStyle是压缩类型,默认是nested(嵌套缩进)、enpanded(无缩进)
//comoact(简介格式)、compressed(压缩)
.pipe(gulpSassmin({
outerStyle: "compressed" }))

.pipe(gulp.dest('dist/css'))

})</pre>

[
复制代码

](javascript:void(0); "复制代码")

直接压缩css文件

安装css所需依赖:cnpm i gulp-clean-css -D

注:下面不管是img,js包括css引入输入源写法和html尽数相同,接直接写最后一种了

再在gulpfile.js中配置,如下:

[
复制代码

](javascript:void(0); "复制代码")

<pre style="margin: 0px; padding: 0px; transition-duration: 0.2s; transition-property: background-color, border-color, border-radius, padding, margin, color, opacity; overflow: auto; font-family: "Courier New"; font-size: 12px; overflow-wrap: break-word;">var gulpCssMin = require('gulp-clean-css')

gulp.task('cssmin', function(){

gulp.src("src/css/**/*.css")

.pipe(gulpCssMin())

.pipe(gulp.dest('dist/css'))

})</pre>

[
复制代码

](javascript:void(0); "复制代码")

压缩img图片

安装css所需依赖:cnpm i gulp-imagemin -D

再在gulpfile.js中配置,如下:

[
复制代码

](javascript:void(0); "复制代码")

<pre style="margin: 0px; padding: 0px; transition-duration: 0.2s; transition-property: background-color, border-color, border-radius, padding, margin, color, opacity; overflow: auto; font-family: "Courier New"; font-size: 12px; overflow-wrap: break-word;">var gulpImgsmin = require('gulp-imagemin');

gulp.task('imgmin', function(){

gulp.src('src/img/**/*')

.pipe(gulpImgsmin())

.pipe(gulp.dest("dist/imgs"))

})</pre>

[
复制代码

](javascript:void(0); "复制代码")

压缩js文件

安装js所需依赖:cnpm i gulp-uglify -D

再在gulpfile.js中配置,如下:

[
复制代码

](javascript:void(0); "复制代码")

<pre style="margin: 0px; padding: 0px; transition-duration: 0.2s; transition-property: background-color, border-color, border-radius, padding, margin, color, opacity; overflow: auto; font-family: "Courier New"; font-size: 12px; overflow-wrap: break-word;">var gulpJsmin = require('gulp-uglify');

gulp.task('jsmin', function(){ //注意,js中可能有多个文件夹,比如说一些插件一些类库之类的,
//所以看你需求而定路径写对就行
gulp.src('src/js/*/.js')

.pipe(gulpJsmin())

.pipe(gulp.dest('dist/js'))

})</pre>

[
复制代码

](javascript:void(0); "复制代码")

注意:js编译有可能会报错,会报错的原因是你所编写的js中可能有es6的语法即ex6以上的语法(就比如说es6的字符串模板,肯定是我们最喜欢用的神器了),如果有的话需要将es6编译成es5;

转义es6

安装所需依赖:cnpm i gulp-babel babel-core babel-preset-env -D

再在gulpfile.js中配置,如下:

[
复制代码

](javascript:void(0); "复制代码")

<pre style="margin: 0px; padding: 0px; transition-duration: 0.2s; transition-property: background-color, border-color, border-radius, padding, margin, color, opacity; overflow: auto; font-family: "Courier New"; font-size: 12px; overflow-wrap: break-word;">var gulpBalel = require('gulp-babel');

gulp.task('default', function(){ //有多个文件存在ex6写法的话也是也可以同时编译多个
gulp.src('src/index.js')

.pipe(gulpBalel({
    presets: ['env']
}))

.pipe(gulp.dest('dist/js'))

})</pre>

[
复制代码

](javascript:void(0); "复制代码")

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352

推荐阅读更多精彩内容

  • npm(node package manager)是nodejs的包管理器,用于node插件管理(包括安装、卸载、...
    lovelydong阅读 444评论 0 2
  • (一)什么是Gulp gulp是前端开发过程中对代码进行构建的工具,它不仅能对网站资源进行优化,而且在开发过程中很...
    _花阅读 481评论 0 1
  • (最近一直搞angularjs.项目里非要用2个包管理器npm和bower,2个任务运行器webpage、gulp...
    Lucky_福星阅读 661评论 1 2
  • 1.背景介绍 gulp是前端开发过程中对代码进行构建的工具,是自动化项目的构建利器;它不仅能对网站资源进行优化,而...
    cczhuc阅读 915评论 0 0
  • gulp入门 gulp是前端开发过程中对代码进行构建的工具,是自动化项目的构建利器;他不仅能对网站资源进行优化,而...
    深愛某女子阅读 200评论 1 1