一、Gulp的介绍及安装
Gulp是基于node平台开发的前端工具
Gulp可以处理日常工作流产生的任务(作用):
项目上线时对HTML、CSS、JavaScript文件合并、压缩;
将ES6语法转换为ES5语法以便代码在较旧的浏览器中运行;
Gulp提供的方法
gulp.src( )——获取任务要处理的文件
![](https://img-blog.csdnimg.cn/img_convert/eb8494f14da1ed8d4ce64f9aa3ec8d67.png)
gulp.dest( )——输出文件
![](https://img-blog.csdnimg.cn/img_convert/f71d92fc4ef54f5a19de062f5f4cff7b.png)
gulp.task( )——建立gulp任务
![](https://img-blog.csdnimg.cn/img_convert/0f7ee4e29550fd67c61ef7afd9cb1ae3.png)
gulp.watch( )——监控文件的变化
![](https://img-blog.csdnimg.cn/img_convert/72020093da1e6baa5843fc6a79b1fa3e.png)
Gulp工具的安装
(1)全局安装gulp-cli:npm install gulp-cli@2.3.0 -g
![](https://img-blog.csdnimg.cn/img_convert/f301ec8b24b0aa4340308486b8c8ee0f.png)
(2)在项目中安装gulp:npm init
npm install gulp@4.0.2 --save-dev
![](https://img-blog.csdnimg.cn/img_convert/8e2a479322575a55c7cdbb5d82766fad.png)
![](https://img-blog.csdnimg.cn/img_convert/33007a389ab9f1be1a7d78dd327d4d3e.png)
![](https://img-blog.csdnimg.cn/img_convert/9677147f4d841c73cd795020712cb25c.png)
(3)构建项目
![](https://img-blog.csdnimg.cn/img_convert/1582cb87c04402b13ef4afaa03b76a14.png)
二、压缩并抽取HTML中的公共代码——html
安装插件
npm install gulp-htmlmin
npm install gulp-file-include
引入模块
// 引入htmlmin插件
const htmlmin = require('gulp-htmlmin')
// 引入gulp-file-include
const fileInclude = require('gulp-file-include')
建立任务
gulp.task('htmlmin', callback => {
gulp.src('./src/*.html')
.pipe(fileInclude())
.pipe(htmlmin({
collapseWhitespace: true
}))
.pipe(gulp.dest('./dist'))
callback();
})
抽取公共部分代码
先把头部公共部分的代码剪切放在common文件夹下面的header.html文件中
@@include()语法是由gulp-file-include插件提供的,小括号中是代码片段的路径以及文件的名字。
在原文件中(article.html)使用@@include('./common/header.html')()里面存放路径
![](https://img-blog.csdnimg.cn/img_convert/ffa9e254be1cd26309ab49b3e5e36a8c.png)
执行任务
gulp htmlmin
代码截图如下:
![](https://img-blog.csdnimg.cn/img_convert/9ee40da87a01a70c3e9ed7c7446d9537.png)
![](https://img-blog.csdnimg.cn/img_convert/4028174c283c6009c5c6e126e82612de.png)
![](https://img-blog.csdnimg.cn/img_convert/955547ad761ce22ffa3f331b1a99dfe4.png)
![](https://img-blog.csdnimg.cn/img_convert/da4c64b885c1cb21e072907716d4a4cb.png)
三、压缩并转换Less语法——css
安装插件
//less转换
npm install gulp-less
//css压缩
npm install gulp-csso
引入模块
// 引入gulp-less插件
const less = require('gulp-less')
// 引入gulp-csso插件
const cssmin = require('gulp-csso')
在css文件夹下面建.less后缀的文件
建立任务
gulp.task('cssmin', callback => {
gulp.src(['./src/*.css', './src/css/*.less'])
.pipe(less())
.pipe(cssmin())
.pipe(gulp.dest('./dist/css'))
callback();
})
执行任务
gulp cssmin
代码截图如下:
![](https://img-blog.csdnimg.cn/img_convert/1d273f98d45ab723c897916e3814b9bd.png)
![](https://img-blog.csdnimg.cn/img_convert/95f29c5a55ad927d8f84556ccdc0db01.png)
![](https://img-blog.csdnimg.cn/img_convert/834479edf02f0f2ebd3dbc86fe71b1e5.png)
![](https://img-blog.csdnimg.cn/img_convert/4f37c0379cfc7bd97249fafa0f479943.png)
![](https://img-blog.csdnimg.cn/img_convert/bebf4434236edc94214bb3a9c5c0e9e3.png)
四、压缩并转换ES6语法——js
安装插件
npm install gulp-uglify
npm install gulp-babel @babel/core @babel/preset-env
引入模块
// 引入gulp-babel插件
const babel = require('gulp-babel')
// 引入gulp-uglify插件
const uglify = require('gulp-uglify')
建立任务
gulp.task('jsmin', callback => {
gulp.src('./src/js/*.js')
.pipe(babel({
presets: ['@babel/env']
}))
.pipe(uglify())
callback();
})
执行任务
gulp jsmin
代码截图如下:
![](https://img-blog.csdnimg.cn/img_convert/692ca968f4d2c3843f57ab09955dacd3.png)
![](https://img-blog.csdnimg.cn/img_convert/2100d30f6fd527bc316a62e2b66cb288.png)
![](https://img-blog.csdnimg.cn/img_convert/db1c1eef36e8f13e2e0e8fd8d02be5b1.png)
![](https://img-blog.csdnimg.cn/img_convert/a811a7b26b88f83b46e9a1e7ef3bd5ce.png)
五、复制目录——copy
![](https://img-blog.csdnimg.cn/img_convert/d03c2a9e7a3780e901bdbac26c23ea25.png)
六、执行全部构建任务
![](https://img-blog.csdnimg.cn/img_convert/cb3a4670a682c28c10d62bd7a9119250.png)
七、项目依赖管理
锁定包的版本,确保再次下载时不会因为包版本不同而产生问题
加快下载速度,因为该文件中已经记录了项目所依赖第三方包的树状结构和包的下载地址,重新安装时只需下载即可,不需要做额外的工作
![](https://img-blog.csdnimg.cn/img_convert/0071e17369be2b8009edf97b10b12fe8.png)
八、Node.js模块加载机制
模块查找规则——当模块拥有路径但没有后缀时
require('./find.js');
require('./find');
1.require方法根据模块路径查找模块,如果是完整路径,直接引入模块;
2. 如果模块后缀省略,先找同名JS文件再找同名JS文件夹;
3. 如果找到了同名文件夹,找文件夹中的index.js;
4. 如果文件夹中没有index.js就会去当前文件夹中package.json文件中查找main选项的入口文件;
5. 如果找指定的入口文件不存在或者没有指定入口文件就会报错,模块没有被找到;
![](https://img-blog.csdnimg.cn/img_convert/4e27585cde8832b58e5176c8297a28de.png)
![](https://img-blog.csdnimg.cn/img_convert/da30b1ada0cad0a979b6c70a94f4f91f.png)
模块查找规则——当模块没有路径且没有后缀时
require('find');
1. Node.js会假设它是系统模块;
2. Node.js会去node_modules文件夹中;
3. 首先看是否有该名字的JS文件;
4. 再看是否有该名字的文件夹;
5. 如果是文件夹看里面是否有index.js;
6. 如果没有index.js查看该文件夹中的package.json中的main选项确定模块入口文件;
7. 否则找不到报错;
![](https://img-blog.csdnimg.cn/img_convert/4fd094a66492f2c690ce4ef3d787d0eb.png)
![](https://img-blog.csdnimg.cn/img_convert/0d0d22abc161bea241453ee93df2102b.png)