gulp-uglify:压缩js大小,只支持es5

安装:

  cnpm: cnpm i gulp-uglify -D

  yarn: yarn add gulp-uglify -D

使用:

代码实现1:压缩js文件夹下的index.js文件输出到dist文件夹下面(注意要压缩的js文件中此处只能使用es5)

 var gulp = require('gulp');
var uglify = require('gulp-uglify'); gulp.task("uglify",function(){
gulp
.src('js/index.js') // 源文件
.pipe(uglify()) // 使用插件
.pipe(gulp.dest('dist')) // 设定输出目录
})

这只是一个简单的js文件压缩,如果我们需要输出到另一个文件夹中并重命名该怎么办?接下来我们的gulp-rename插件粉墨登场!!

gulp-rename:重命名插件

安装:

  cnpm: cnpm i gulp-rename -D

  yarn: yarn add gulp-rename -D

基本使用:

 var gulp = require('gulp');
var rename = require('gulp-rename') gulp.task('rename',function(){
console.log('开始重命名JS.....');
gulp
.src('js/index.js') // 源
// 1、字符串:适用于单文件重命名
.pipe(rename('index.min.js'))
// 2、函数:适用于需要进行判断的多文件重命名
.pipe(rename(function(path){ //(可以打印一下path看下里面的内容,方便理解)
path.dirname ='./js' // 输出目录的dist下目录名称
path.basename +='.min' // 文件名
path.extname='.min.js' // 后缀名(文件名和后缀名选择一个进行配置) })) // 3、对象:适用于多文件(推荐使用)
.pipe(rename({
dirname: "./js", // 输出目录的dist下目录名称
basename: "", // 文件名
prefix: "前缀-", // 文件名前缀
suffix: "-后缀", // 文件名后缀
extname: ".md" // 扩展名
}))
.pipe(gulp.dest('dist')) // 输出目录
})

代码实现2:压缩js文件夹下的index.js文件输出到dist文件夹下面,并重命名为index.min.js

 var gulp = require('gulp');
var uglify = require('gulp-uglify');
var rename = require("gulp-rename"); gulp.task("uglify",function(){
gulp
.src('js/index.js') // 源
.pipe(uglify()) // 使用压缩插件
.pipe(rename({
dirname: "./js", //输出到输出目录下的js目录下
suffix: ".min", // 给文件名加后缀
}))
.pipe(gulp.dest('dist')) // 设定输出目录
})

  那么,现在又会出现一个问题,我如果想压缩不同目录下的js文件又该怎么办,或者说我想压缩的js文件中有es6,那又怎么办,别着急,我们先来解决压缩不同目录下的js文件,那么我们又将遇到一个老朋友‘*’,是不是很熟悉,通配符,css中是不是经常会使用到,这里我们也可以使用*和**来进行通配。

  *匹配字符,**匹配字符包括“/”也就是目录,你是不是有想法了?

我们此处将在 gulp.src('js/index.js') 处做文章

  gulp.src('js/*.js')  //将会匹配js下所有的js文件  

  gulp.src('js/**/*.js')  //将会匹配js下所有目录下的js文件 ,不管你的目录有多深,只有你在js文件夹下面,只有你里面包含js文件,使用这种办法都会被匹配到 

代码实现3:压缩js文件夹下的所有的js文件输出到dist文件夹下面,并每个js文件名后都加上.min

 var gulp = require('gulp');
var uglify = require('gulp-uglify');
var rename = require("gulp-rename"); gulp.task("uglify",function(){
gulp
.src("js/**/*.js") //匹配js文件夹下的所有js文件
.pipe(uglify())//压缩文件
.pipe(rename({
suffix:".min" //给所有的文件名加上后缀.min
}))
.pipe(gulp.dest("dist")) //输出到dist文件夹下面
})

事情进行到这里,已经完成了很大一部分我们的需求了,那么接下来我们再来搞定可以支持压缩es6的问题,这里我们又使用到了一个插件gulp-babel插件

gulp-babel:可以将ES6代码转为ES5代码

安装:

  cnpm: cnpm i gulp-babel -D

  yarn: yarn add gulp-babel -D

代码实现4:压缩js文件夹下的所有的js文件输出到dist文件夹下面,并每个js文件名后都加上.min,并且支持es6压缩

 var gulp = require('gulp');
var uglify = require('gulp-uglify');
var rename = require("gulp-rename");
const babel = require('gulp-babel'); gulp.task("uglify",function(){
gulp
.src("js/**/*.js")
.pipe(babel({
presets: ['@babel/env']
}))//es6转es5
.pipe(uglify())
.pipe(rename({
suffix:".min"
}))
.pipe(gulp.dest("dist"))
})

好了,现在我们的目标已经实现了,你完全可以自己发挥自己的想象力去任意压缩js文件了!

gulp插件实现压缩一个文件夹下不同目录下的js文件(支持es6)的更多相关文章

  1. WPF 获取文件夹路径,目录路径,复制文件,选择下载文件夹/目录

    private void Border_MouseLeftButtonUp_4(object sender, MouseButtonEventArgs e) { //获取项目中文件 , System. ...

  2. linux 下怎样查找一个文件夹在哪个目录下?

    如果只显示所在目录的路径: find 目录 -type d -name "查询目录名" -printf "%h\n" 如果同时显示目录名称和所在目录的路径: f ...

  3. 怎样把.git版本控制文件夹放在项目目录下

    在上传本地代码到本地git库时,.git的存放目录不能放到项目根目录下(报错). 可以先把.git仓库选择其他保存路径,然后再copy到项目根目录下.

  4. JFinal中文件上传后会默认放置到WebContent的upload包下,但是tomcat会自动重启,当我们再次打开upload文件夹查看我们刚刚上传的文件时,发现上传的文件已经没有了。

    JFinal中文件上传后会默认放置到WebContent的upload包下,但是tomcat会自动重启,当我们再次打开upload文件夹查看我们刚刚上传的文件时,发现上传的文件已经没有了.因为tomc ...

  5. 一个网站同一域名不同目录下的文件访问到的cookie值不同是什么原因?

    一个网站(e:\test):里面包含多个目录如: html css js php img ..... 等等.然后,我在js目录里面的js文件中设置了cookie:同样也在php目录中的php文件中设置 ...

  6. <每日一题>题目11:以文件夹名称作为参数,返回该文件夹下所有文件的路径

    ''' 分析: 1.知道文件夹名称(假设是形如:E:\\software\\Notepad++),很显然可以通过OS模块去求 2.OS.listdir(sPath),列出文件夹内所有的文件和文件夹,以 ...

  7. Android加载SD卡目录,文件夹遍历,图片设置,设置文件对应打开方式等

    此案例主要说的是Android使用GridView加载SD卡下所有目录,文件夹多层遍历,文件图标修改,设置文件对应打开方式等功能. 如图: 代码: public class GridViewFile ...

  8. selector是在文件夹drawable中进行定义的xml文件。

    获取Drawable对象: Resources res = mContext.getResources(); Drawable myImage = res.getDrawable(R.drawable ...

  9. JavaSE 文件递归之删除&amp;获取文件夹文件夹中全部的以.jpg的文件的绝对路径

    1.递归删除文件 假设一个文件夹以下还有子文件夹,进行删除的话会 报错,这个时候要使用递归的方式来删除这个文件文件夹中的全部文件以及文件夹 package cn.itcast.digui; impor ...

随机推荐

  1. js基础 -函数

    函数 定义 var a =function (){...}; 匿名函数方式定义function a(){} 直接定义 函数的参数arguments 可以接收任意个参数,是个像数组的内容,可for in ...

  2. webpack4.0.1安装问题和webpack.config.js的配置变化

    The CLI moved into a separate package: webpack-cli. Please install 'webpack-cli' in addition to webp ...

  3. 贝塞尔曲线java实现

    主类:BezierFrame package bezierT; import java.awt.Color; import java.awt.Dimension; import java.awt.Ev ...

  4. python commands包不支持windows环境与如何在windows下使用的简易方法

    commands模块不支持windows环境,让我们来看看. >>> import commands >>> print commands.getoutput('d ...

  5. Java基础(面试题)

    1:面向对象编程有很多重要的特性: 封装,继承,多态和抽象. 2:什么是Java虚拟机?为什么Java被称作是“平台无关的编程语言”? (1)Java虚拟机是一个可以执行Java字节码的虚拟机进程.J ...

  6. react github项目

    https://github.com/bailicangdu/react-pxq 网址;https://github.com/bailicangdu/react-pxq

  7. Nuxt 自动化部署及打包后文件自动上传七牛云

    1.安装七牛云 2.在项目根目录新建 upload.js 3.上传凭证 4.上传配置,详情参考七牛云文档 5.在 package.js中修改项目build完成执行upload文件命令 7. nuxt. ...

  8. java学习之成员内部类

    //成员内部类:直接在类中定义 /*成员内部类的通常用法: * 通常是提供给外部类使用不进行内部类的实例化 * 因此一般把他设为私有的类用private限定 * * */ /*Demo*/ class ...

  9. eslint的安装与使用

    什么是 ESLint ESLint(中文站点)是一个开源的 JavaScript 代码检查工具,使用 Node.js 编写,由 Nicholas C. Zakas 于 2013 年 6 月创建.ESL ...

  10. 【Python学习】iterator 迭代器小练习

    http://anandology.com/python-practice-book/iterators.html  Problem 1: Write an iterator class revers ...