博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
gulp压缩合并js与css
阅读量:6113 次
发布时间:2019-06-21

本文共 3398 字,大约阅读时间需要 11 分钟。

前言

webpack是应用非常广泛的打包软件,但是,webpack侧重于用 依赖管理整个静态资源。

假如没有依赖呢?

查了一番资料,准备使用gulp一试。

简介

gulp是一个基于流式的任务处理工具,以default任务为入口。

gulp.task('default', function() {  // do you want})复制代码

安装

我只需要如下功能,对应的安装包为:

  • gulp 打包
  • gulp-uglify 压缩js
  • gulp-clean-css 压缩css
  • gulp-imagemin 压缩图片
  • gulp-concat 合并文件
  • gulp-clean 清理文件夹

npm或者yarn安装

npm i -S gulp gulp-uglify gulp-clean-css gulp-imagemin gulp-concat gulp-clean# 或yarn add --dev gulp gulp-uglify gulp-clean-css gulp-imagemin gulp-concat gulp-clean复制代码

目录树结构

├── dist #打包后目录├── src #源码目录|   ├── js|   |   └── lib #第三方包|   ├── css|   └── img├── gulpfile.js #gulp配置文件└── index.html #html文件复制代码

配置gulpfile.js

压缩合并 js

无依赖的项目中,js 加载顺序有时候会影响代码逻辑,所以把第三方包单独放入一个文件夹,先进行打包。

第三方包打包成vendor.js,其余逻辑打包成 app.js

gulp.task('m-js', function() {  gulp    .src(SRC + 'js/lib/*.js')    .pipe(concat('vendor.js'))    .pipe(uglify())    .pipe(gulp.dest(DEST + 'js'))  gulp    .src(SRC + 'js/*.js')    .pipe(concat('app.js'))    .pipe(uglify())    .pipe(gulp.dest(DEST + 'js'))})复制代码

压缩合并css

gulp.task('m-css', () => {  gulp    .src(SRC + 'css/*.css')    .pipe(concat('main.css'))    .pipe(cleanCSS({ compatibility: 'ie8' }))    .pipe(gulp.dest(DEST + 'css'))})复制代码

压缩图片

gulp.task('m-img', function() {  gulp    .src(SRC + 'img/*')    .pipe(      imagemin({        progressive: true      })    )    .pipe(gulp.dest(DEST + '/img'))})复制代码

其他优化

清理目标文件夹

每次打包前需清理目标文件夹,且必须在清理之后才开始重新打包,所以在default任务里使用异步操作。

// 清除与打包异步执行gulp.task('build', ['m-js', 'm-css', 'm-img'])gulp.task('default', ['clean'], function() {  return gulp.start('build')})复制代码

最后文件的 整体代码如下:

// gulp核心文件var gulp = require('gulp')// 压缩jsvar uglify = require('gulp-uglify')// 压缩cssvar cleanCSS = require('gulp-clean-css')// 压缩图片var imagemin = require('gulp-imagemin')// 合并文件var concat = require('gulp-concat')// 清除打包目录var clean = require('gulp-clean')var SRC = 'src/'var DEST = 'dist/'// 压缩合并jsgulp.task('m-js', function() {  gulp    .src(SRC + 'js/lib/*.js')    .pipe(concat('vendor.js'))    .pipe(uglify())    .pipe(gulp.dest(DEST + 'js'))  gulp    .src(SRC + 'js/*.js')    .pipe(concat('app.js'))    .pipe(uglify())    .pipe(gulp.dest(DEST + 'js'))})// 压缩合并cssgulp.task('m-css', () => {  gulp    .src(SRC + 'css/*.css')    .pipe(concat('main.css'))    .pipe(cleanCSS({ compatibility: 'ie8' }))    .pipe(gulp.dest(DEST + 'css'))})// 压缩图片gulp.task('m-img', function() {  gulp    .src(SRC + 'img/*')    .pipe(      imagemin({        progressive: true      })    )    .pipe(gulp.dest(DEST + '/img'))})// 清除目标文件夹gulp.task('clean', function() {  return gulp.src('dist').pipe(clean())})// 开发的时候在命令行启动// $ gulp autogulp.task('auto', function() {  gulp.watch(SRC + 'js/lib/*', ['m-js'])  gulp.watch(SRC + 'js/*', ['m-js'])  gulp.watch(SRC + 'css/*.css', ['m-css'])  gulp.watch(SRC + 'img/*', ['m-img'])})// 清除与打包异步执行gulp.task('build', ['m-js', 'm-css', 'm-img'])// gulp 入口gulp.task('default', ['clean'], function() {  return gulp.start('build')})复制代码

监听

开发时需要监听目标文件的改动,立即打包。

gulp.task('auto', function() {  gulp.watch(SRC + 'js/lib/*', ['m-js'])  gulp.watch(SRC + 'js/*', ['m-js'])  gulp.watch(SRC + 'css/*.css', ['m-css'])  gulp.watch(SRC + 'img/*', ['m-img'])})复制代码

使用

设置 package.json 的脚本。

  • 打包 npm run build
  • 开发时监听 npm run dev
{  "scripts": {    "build": "gulp --config gulpfile.js",    "dev": "gulp auto"  }}复制代码

后记

这个工具还是用得少,目前发现的一些不足:

  • js里不能使用es6语法,不然报错

毕竟现在使用es6import才是规范,情况允许的情况下还是使用webpack更好。

转载于:https://juejin.im/post/5bfcb1a2e51d455c652ecc15

你可能感兴趣的文章
ES6系列之Promise, Generator, Async比较
查看>>
[LeetCode] 403. Frog Jump
查看>>
Go net 超时处理
查看>>
Node.js 指南(关于Node.js)
查看>>
前端调试入门
查看>>
聊聊storm的IWaitStrategy
查看>>
函数范式入门(什么是函数式编程)
查看>>
吴恩达机器学习笔记-反向传播算法练习
查看>>
关于PHP精确计算模块
查看>>
在 CenOS7 下 Erlang 安装部署
查看>>
localhost、本地IP下页面渲染不同 原理解析
查看>>
Python的SQL性能测试
查看>>
【JavaScript】面向对象之RegExg类型
查看>>
高程3总结#第24章最佳实践
查看>>
Nginx Beginner's Guide
查看>>
ES6语法总结
查看>>
数组实例
查看>>
window.open 打开新窗口被拦截的解决方案
查看>>
如何删除Git仓库中冗余的tag?
查看>>
October CMS - 快速入门 5 创建插件
查看>>