一、初始化

首先先做一个项目初始化,用来记录你项目中用到的工具

再你项目文件下打开一个控制台,输入命令 yarn init -y 进行初始化

输入命令yarn add gulp -g  --- 全局安装gulp,这里我提前已经安装过了就不演示了,然后再输入命令yarn add gulp -S 局部安装,都安装完成过后输入命令 gulp -v,如果出现两个版本号,就代表都安装成功了

接着在你的项目文件夹下新建一个文件名为 gulpFile.js js文件,名字必须叫这个,官方规定的,用来写gulp命令

好了,可以开始安装压缩工具进行压缩了

二、html压缩

安装html压缩工具,输入命令

yarn add gulp-htmlmin -D

安装压缩html的工具,安装到开发环境,生产环境用不到

安装完成过后打开初始化时生成的文件 package.json,开发环境有没有你刚安装的 gulp-htmlmin

打开开始建的 gulpFile.js 文件,开始写命令

const gulp = require('gulp') //引入gulp
const htmlmin = require('gulp-htmlmin') //引入html压缩模块
const path = { //方便管理路径
html: {
src: 'src/**/*.html',
dest: 'dist'
}
}
gulp.task('html', () => { //创建任务,并命名任务名
/*一个*表示所有文件,两个*表示所有目录*/
return gulp.src(path.html.src) //打开读取文件
.pipe(htmlmin({
removeComments: true, //清除HTML注释
collapseWhitespace: true, //压缩HTML
collapseBooleanAttributes: true, //省略布尔属性的值 <input checked="true"/> ==> <input checked />
removeEmptyAttributes: true, //删除所有空格作属性值 <input id="" /> ==> <input />
removeScriptTypeAttributes: false, //删除<script>的type="text/javascript"
removeStyleLinkTypeAttributes: true, //删除<style>和<link>的type="text/css"
minifyJS: true, //压缩页面JS
minifyCSS: true //压缩页面CSS
})) //管道流操作,压缩文件
.pipe(gulp.dest(path.html.dest)) //指定压缩文件放置的目录
})

然后输入命令

gulp html

执行压缩

像这样就压缩成功了

上面是 gulp3 写法,gulp4 写法:

const gulp = require('gulp') //引入gulp
const htmlmin = require('gulp-htmlmin') //引入html压缩模块
const path = { //方便管理路径
html: {
src: 'src/**/*.html',
dest: 'dist'
}
}
const html = () => { //创建任务,并命名任务名
/*一个*表示所有文件,两个*表示所有目录*/
return gulp.src(path.html.src) //打开读取文件
.pipe(htmlmin({
removeComments: true, //清除HTML注释
collapseWhitespace: true, //压缩HTML
collapseBooleanAttributes: true, //省略布尔属性的值 <input checked="true"/> ==> <input checked />
removeEmptyAttributes: true, //删除所有空格作属性值 <input id="" /> ==> <input />
removeScriptTypeAttributes: false, //删除<script>的type="text/javascript"
removeStyleLinkTypeAttributes: true, //删除<style>和<link>的type="text/css"
minifyJS: true, //压缩页面JS
minifyCSS: true //压缩页面CSS
})) //管道流操作,压缩文件
.pipe(gulp.dest(path.html.dest)) //指定压缩文件放置的目录
} module.exports = { //一定要以对象形式导出
html
}

三、css压缩

安装css压缩模块,输入命令

yarn add gulp-clean-css -D

然后也在gulpFile.js文件里写压缩css的命令

const gulp = require('gulp') //引入gulp
const htmlmin = require('gulp-htmlmin') //引入html压缩模块
const cleanCss = require('gulp-clean-css') //引入css压缩模块
const path = { //方便管理路径
/*一个*表示所有文件,两个*表示所有目录*/
html: {
src: 'src/**/*.html',
dest: 'dist'
},
css: {
src: 'src/**/*.css',
dest: 'dist'
}
} gulp.task('css', () => {
return gulp.src(path.css.src)
.pipe(cleanCss())
.pipe(gulp.dest(path.css.dest))
})

输入命令 gulp css 命令执行

另外css还有一个很好用的模块,它可以自动给需要兼容的css属性加前缀,输入命令安装它

yarn add gulp-autoprefixer -D

安装好了,引入模块,调用即可

四、js压缩

安装js es6语法转es5语法模块,压缩js模块,输入命令

yarn add -D gulp-babel @babel/core @babel/preset-env //es6语法转es5
yarn add -D gulp-uglify //压缩js

同样的打开 gulpFile.js 文件写压缩js的命令

const gulp = require('gulp') //引入gulp
const htmlmin = require('gulp-htmlmin') //引入html压缩模块
const cleanCss = require('gulp-clean-css') //引入css压缩模块
const autoprefixer = require('gulp-autoprefixer') //引入加前缀模块
const babel = require('gulp-babel'), //引入es6转es5模块
uglify = require('gulp-uglify') //引入js压缩模块
const path = { //方便管理路径
/*一个*表示所有文件,两个*表示所有目录*/
html: {
src: 'src/**/*.html',
dest: 'dist'
},
css: {
src: 'src/**/*.css',
dest: 'dist'
},
js: {
src: 'src/**/*.js',
dest: 'dist'
}
}
gulp.task('js', () => {
gulp.src(path.js.src)
.pipe(babel({
presets: ['@babel/env'] //es6转es5
}))
.pipe(uglify()) //执行压缩
.pipe(gulp.dest(path.js.dest))
})

输入命令 gulp js 运行

五、监听任务

监听任务需要使用gulp4的写法

const gulp = require('gulp') //引入gulp
const htmlmin = require('gulp-htmlmin') //引入html压缩模块
const cleanCss = require('gulp-clean-css') //引入css压缩模块
const autoprefixer = require('gulp-autoprefixer') //引入加前缀模块
const babel = require('gulp-babel'), //引入es6转es5模块
uglify = require('gulp-uglify') //引入js压缩模块
const path = { //方便管理路径
/*一个*表示所有文件,两个*表示所有目录*/
html: {
src: 'src/**/*.html',
dest: 'dist'
},
css: {
src: 'src/**/*.css',
dest: 'dist'
},
js: {
src: 'src/**/*.js',
dest: 'dist'
}
} const css = () => {
return gulp.src(path.css.src)
.pipe(autoprefixer())
.pipe(cleanCss())
.pipe(gulp.dest(path.css.dest))
}
const js = () => {
return gulp.src(path.js.src)
.pipe(babel({
presets: ['@babel/env'] //es6转es5
}))
.pipe(uglify()) //执行压缩
.pipe(gulp.dest(path.js.dest))
} const html = () => { //创建任务,并命名任务名
return gulp.src(path.html.src) //打开读取文件
.pipe(htmlmin({
removeComments: true, //清除HTML注释
collapseWhitespace: true, //压缩HTML
collapseBooleanAttributes: true, //省略布尔属性的值 <input checked="true"/> ==> <input checked />
removeEmptyAttributes: true, //删除所有空格作属性值 <input id="" /> ==> <input />
removeScriptTypeAttributes: false, //删除<script>的type="text/javascript"
removeStyleLinkTypeAttributes: true, //删除<style>和<link>的type="text/css"
minifyJS: true, //压缩页面JS
minifyCSS: true //压缩页面CSS
})) //管道流操作,压缩文件
.pipe(gulp.dest(path.html.dest)) //指定压缩文件放置的目录
}
const watch = () => { //监听文件,文件改变执行对应的任务
gulp.watch(path.html.src, html)
gulp.watch(path.css.src, css)
gulp.watch(path.js.src, js)
} module.exports = {
html,
js,
css,
watch
}

输入命令 gulp watch 即可实现监听

六、gulp创建服务器

输入命令

yarn add gulp-connect -D

引入模块

const connect = require('gulp-connect')

创建服务器

const server = () => {
connect.server({ //创建服务器
root: 'dist',//根目录
port: '2000',//端口号
livereload:true//服务器热更新
})
}

导出模块

module.exports = {
html,
js,
css,
watch,
server
}

输入命令 gulp server 就可以运行了

如果想直接打开首页,可以输入命令安装open模块

yarn add open -S

然后再任何位置写入你想打开的网址

open('http://127.0.0.1:2000')

还有一个模块也可以创建服务器

输入命令安装

yarn add gulp-webServer -D

引入模块

const    webserver = require('gulp-webserver')

创建服务器

const createServer = () => {
return gulp.src('./dist')
.pipe(webserver({ //创建服务器
port:'3000', //端口号
open:'/html', //默认打开路径
livereload:true //热更新
}))
}

七、同时运行多个任务

// 默认任务:default 我们可以把所有任务都放进default
// series 同步执行,先执行删除dist任务,再执行其他任务
// parallel 异步执行(并行),不会互相影响的任务可以并行
module.exports.default = gulp.series(gulp.parallel(html,js,css,watch,server))

运行只需要写 gulp 命令

如果想页面实时更新的话,再想实时更新的任务后面加上

.pipe(connect.reload())

然后重启服务器就ok了

八、反向代理

输入命令

yarn add http-proxy-middleware -D

引入模块

const proxy = require('http-proxy-middleware')

创建反向代理

const server = () => {
connect.server({ //创建服务器
root: 'dist', //根目录
port: '2000', //端口号
livereload: true, //服务器热更新
middleware: () => {
return [
proxy.createProxyMiddleware('/api', { //创建反向代理,请求已 /api 开头就使用target的服务器
target: 'http://localhost',//需要代理的服务器
changeOrigin: true
})
]
} })
}

gulp压缩html,css,js文件流程、监听任务、使用gulp创建服务器、同时运行多个任务、反向代理的更多相关文章

  1. Django使用本地css/js文件

    Django使用本地css/js文件 在manager.py同层级下创建static文件夹, 里面放上css , js, images等文件或者文件夹 我的文件夹层级 然后只需在settings.py ...

  2. Gulp:静态资源(css,js)版本控制

    为了防止客户端的静态资源缓存,我们需要每次更新css或js的时候,通过md5或时间戳等方式重新命名静态资源: 然后涉及到的html模板里的src也要做相应的修改,静态资源需要优化(压缩合并) 文件目录 ...

  3. js活jQuery实现动态添加、移除css/js文件

    下面是在项目中用到的,直接封装好的函数,拿去在js中直接调用就可以实现css.js文件的动态引入与删除.代码如下 动态加载,移除,替换css/js文件 // 动态添加css文件 function ad ...

  4. 在桌面右键创建html,css,js文件

    1.在开始里面输入regedit,进入注册表编辑器. 2.打开HKEY_CLASSES_ROOT项. 3.打开.html/.css/.js项. 4.右键新建项,起名ShellNew. 5.新建字符串值 ...

  5. jsp 引用css/js文件返回html网页问题

    我的问题: 我直接在web.xml中匹配了 “/” ,以为能默认使用 “localhost:8080/news/” 这种方式,直接进入首页. 但是这样会匹配所有url 因此请求的 ***.js/*** ...

  6. JS通用事件监听函数

    JS通用事件监听函数 版本一 //把它全部封装到一个对象中 var obj={ readyEvent:function (fn){ if(fn==null){ fn=document; } var o ...

  7. js进阶 12-6 监听鼠标滚动事件和窗口改变事件怎么写

    js进阶 12-6 监听鼠标滚动事件和窗口改变事件怎么写 一.总结 一句话总结:滚动事件scroll(),浏览器窗口调整监听resize(),思考好监听对象. 1.滚动事件scroll()的监听对象是 ...

  8. 修改 processor.php 文件,监听用户对该应用的消息

    修改 processor.php 文件,监听用户对该应用的消息 class cgc_fdModuleProcessor extends WeModuleProcessor { public funct ...

  9. js添加事件监听的方式与this

    js添加事件监听与this js添加事件监听的方式与this 在标签中调用自定义函数 DOM0级事件处理程序 DOM2级事件处理程序 this 代表谁? js添加事件监听的方式与this <di ...

随机推荐

  1. 搭建Istio基础环境

    需求 搭建istio基础环境(基于1.5.1版本) 安装步骤 在安装 Istio 之前,需要一个运行着 Kubernetes 的环境,安装步骤可以参考前面的文章 下载istio,然后解压,然后将 is ...

  2. 【JUC】synchronizated和lock的区别&新lock的优势

    原始构成 synchronized是关键字,属于JVM层面 javap -c 的结果显示 synchronized是可重入锁 11:是正常退出 17:是异常退出[保证不产生死锁和底层故障] Lock是 ...

  3. Java的字节流,字符流和缓冲流对比探究

    目录 一.前言 二.字节操作和字符操作 三.两种方式的效率测试 3.1 测试代码 3.2 测试结果 3.3 结果分析 四.字节顺序endian 五.综合对比 六.总结 一.前言 所谓IO,也就是Inp ...

  4. 百万年薪架构师一文整理RabbitMQ、ActiveMQ、RocketMQ、Kafka

    一般来说,大型应用通常会被拆分成多个子系统,这些子系统可能会部署在多台机器上,也可能只是一台机器的多个进程中,这样的应用就是分布式应用.在讨论分布式应用时,很多初学者会把它和集群这个概念搞混,因为从部 ...

  5. Chisel3 - util - LFSR16

    https://mp.weixin.qq.com/s/DSdb4tmRwDTOki7mbyuu9A     实现16位线性反馈移位寄存器.可用于生成简单的伪随机数.     ​​     ​​   参 ...

  6. 震惊!Windows Service服务和定时任务框架quartz之间原来是这种关系……

    过场CG:   接到公司领导的文件指示,“小熊”需要在6月底去海外执行一个行动代号为[定时任务]的营救计划,这个计划关系到公司某个项目的生死(数据安全漏洞),作战部拟定两个作战方案: 方案一:使用务定 ...

  7. Mysql安装与设置用户名、密码

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 关于MySQL程序中数据库调度的流程图解: ​ 1-MySql数据库的安装 ​ 安装前要注意,看看当前系 ...

  8. Java实现 LeetCode 321 拼接最大数

    321. 拼接最大数 给定长度分别为 m 和 n 的两个数组,其元素由 0-9 构成,表示两个自然数各位上的数字.现在从这两个数组中选出 k (k <= m + n) 个数字拼接成一个新的数,要 ...

  9. Java实现蓝桥杯方格计数

    标题:方格计数 如图p1.png所示,在二维平面上有无数个1x1的小方格. 我们以某个小方格的一个顶点为圆心画一个半径为 50000 的圆. 你能计算出这个圆里有多少个完整的小方格吗? 注意:需要提交 ...

  10. Java实现 蓝桥杯 算法提高 快速排序

    试题 算法提高 快速排序 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 用递归来实现快速排序(quick sort)算法.快速排序算法的基本思路是:假设要对一个数组a进行排序,且a ...