前端必会的轻量打包工具gulp使用详解

 更新时间:2022年11月03日 16:16:20   作者:mapengfei  
这篇文章主要为大家介绍了前端必会的轻量打包工具gulp使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

一. 安装Node和gulp

gulp 是基于 node 实现 Web 前端自动化开发的工具,利用它能够极大的提高开发效率。

在 Web 前端开发工作中有很多“重复工作”,比如压缩CSS/JS文件。而这些工作都是有规律的。找到这些规律,并编写 gulp 配置代码,让 gulp 自动执行这些“重复工作”。

安装node: 由于gulp是基于node实现的,所以要先安装node

node安装

安装gulp

 npm install -g gulp

 安装

 gulp -v

查看版本

二.使用gulp压缩Js

压缩js文件可以降低js文件的大小,提高页面打开速度。

2.1 方法

  • 找到要压缩的所有的js文件,压缩它们,将压缩后的文件放在 dist/js/目录下

2.2 步骤

1. 创建gulp-demo文件夹,使用npm初始化项目

 npm init

2. 在项目根目录新建一个gulpfile.js文件

  • gulp所有的配置都在这个文件里面

3. 在gulpfile文件中书写压缩js文件的代码,安装gulp 和 gulp-uglify压缩模块

 //获取gulp对象
 const gulp = require("gulp")
 // 压缩js文件的对象,使用之前需要安装
 // 安装方法:npm i gulp-uglify -D
 const uglify = require("gulp-uglify")
 // 定义压缩文件的处理方法
 function script(){
     //1. 匹配要所有压缩的js文件
     gulp.src('js/*.js')
     //2. 压缩文件
    .pipe(uglify())
     //3. 将压缩后的文件写入指定目录
    .pipe(gulp.dest('dist/js'))
 }
 //将定义好的压缩方法暴露给外界
 exports.script = gulp.series(script);
 npm i gulp gulp-uglify -D

4. 在项目根目录创建js文件夹并且创建需要测试的js文件

5. 在命令行输入如下命令运行

  • 由于我们导入的为 script,所以这里输入gulp script命令即可
 gulp script
  • 压缩后的目录如下所示

6. 升级压缩功能,每次文件修改之后,自动压缩打包

 //获取gulp对象
 const gulp = require("gulp")
 // 压缩js文件的对象,使用之前需要安装
 // 安装方法:npm i gulp-uglify -D
 const uglify = require("gulp-uglify")
 // 定义压缩文件的处理方法
 function script(){
     //1. 匹配要所有压缩的js文件
     gulp.src('js/*.js')
     //2. 压缩文件
    .pipe(uglify())
     //3. 将压缩后的文件写入指定目录
    .pipe(gulp.dest('dist/js'))
 }
 //创建监听js文件的方法
 function autoScript(){
     // 创建监听对象
     var watcher = gulp.watch("js/*.js");
     //分别监听 change,add,unlink事件
     watcher.on("change",function(path,stats){
         console.log(`${path} has been changed!`);
    });
     watcher.on("add",function(path,stats){
         console.log(`${path} has been add!`);
    });
     watcher.on("unlink",function(path,stats){
         console.log(`${path} has been unlink!`);
    })
 }
 //将定义好的压缩方法暴露给外界,并作为gulp的默认值
 // exports.script = gulp.series(script,autoScript);
 exports.autoScript = gulp.parallel(script,autoScript);
  • 运行
 gulp autoScript

7. 使用 exports.default 定义默认任务

 //如上所示,我们使用 export script 和 export autoScript命令执行任务
 //可以通过 exports.default 关键字指定默认任务
 exports.default = gulp.parallel(script,autoScript);
  • 设置完成之后,在命令行输入 gulp即可启动任务
 gulp
  • 完整项目目录:gulp-demo(压缩js)
  • 注意:所有的项目,下载之后先在项目根目录要运行 npm i命令安装模块

三. 压缩CSS文件

CSS文件压缩过程类似于Js文件,这里做简单介绍

3.1 步骤

1.创建gulpfile.js文件

2. 安装压缩CSS文件需要用到的模块

 npm i gulp gulp-minify-css -D

3. 在项目根目录创建CSS文件夹,在CSS文件夹下面创建要测试的CSS文件

4. 编写压缩代码,到处任务调用

 //获取gulp对象
 const gulp = require("gulp")
 //获取压缩 css文件的方法
 const minifyCss = require("gulp-minify-css")
 // 定义压缩文件的处理方法
 function css(){
    //1. 匹配要所有压缩的css文件
    gulp.src('css/*.css')
    //2. 压缩文件
    .pipe(minifyCss())
    //3. 将压缩后的文件写入指定目录
    .pipe(gulp.dest('dist/css'))
 }
 //升级:自动监听文件的改变,
 //创建监听js文件的方法
 function autoCss(){
    // 创建监听对象
    var watcher = gulp.watch("css/*.css");
    //分别监听 change,add,unlink事件
    watcher.on("change",function(path,stats){
        console.log(`${path} has been changed!`);
    });
    watcher.on("add",function(path,stats){
        console.log(`${path} has been add!`);
    });
    watcher.on("unlink",function(path,stats){
        console.log(`${path} has been unlink!`);
    })
 }
 //将定义好的压缩方法暴露给外界,并作为gulp的默认值
 // exports.default = gulp.series(css,autoCss);
 exports.autoCss = gulp.parallel(css,autoCss);

5. 运行文件

 gulp autoCss
  • 完整项目目录:gulp-demo(压缩CSS)
  • 注意:所有的项目,下载之后先在项目根目录要运行 npm i命令安装模块

四. 压缩图片

方法同上压缩js 和CSS文件,以下给出压缩图片的依赖模块,以及示例代码

依赖模块: gulp ,gulp-imagemin

代码示例:

 //获取gulp对象
 const gulp = require("gulp")
 //获取压缩 图片文件的对象
 const imagemin = require("gulp-imagemin")
 // 定义压缩文件的处理方法
 function images(){
     //1. 匹配要所有压缩的图片文件
     gulp.src('imgs/*.*')
     //2. 压缩文件
    .pipe(imagemin({
         progressive: true
    }))
     //3. 将压缩后的文件写入指定目录
    .pipe(gulp.dest('dist/imgs'))
 }
 //升级:自动监听文件的改变,
 //创建监听图片文件的方法
 function autoImages(){
     // 创建监听对象
     var watcher = gulp.watch("imgs/*.*");
     //分别监听 change,add,unlink事件
     watcher.on("change",function(path,stats){
         console.log(`${path} has been changed!`);
    });
     watcher.on("add",function(path,stats){
         console.log(`${path} has been add!`);
    });
     watcher.on("unlink",function(path,stats){
         console.log(`${path} has been unlink!`);
    })
 }
 //将定义好的压缩方法暴露给外界,并作为gulp的默认值
 // exports.images = gulp.series(images,autoImages);
 exports.autoImages = gulp.parallel(images,autoImages);
  • 完整项目目录:gulp-demo(压缩图片)
  • 注意:所有的项目,下载之后先在项目根目录要运行 npm i命令安装模块

五. 编译Less文件

模块: gulp,gulp-less

示例:

 //获取gulp对象
 const gulp = require("gulp")
 //获取压缩 less文件的对象
 const gulpLess = require("gulp-less")
 // 定义压缩文件的处理方法
 function less(){
     //1. 匹配要所有压缩的less文件
     gulp.src('less/*.less')
     //2. 压缩文件
    .pipe(gulpLess())
     //3. 将压缩后的文件写入指定目录
    .pipe(gulp.dest('dist/less'))
 }
 //升级:自动监听文件的改变,
 //创建监听less文件的方法
 function autoLess(){
     // 创建监听对象
     var watcher = gulp.watch("less/*.less");
     //分别监听 change,add,unlink事件
     watcher.on("change",function(path,stats){
         console.log(`${path} has been changed!`);
    });
     watcher.on("add",function(path,stats){
         console.log(`${path} has been add!`);
    });
     watcher.on("unlink",function(path,stats){
         console.log(`${path} has been unlink!`);
    })
 }
 //将定义好的压缩方法暴露给外界,并作为gulp的默认值
 // exports.images = gulp.series(less,autoLess);
 exports.autoLess = gulp.parallel(less,autoLess);
  • 完整项目目录:gulp-demo(编译less)
  • 注意:所有的项目,下载之后先在项目根目录要运行 npm i命令安装模块

六. 编译Sass文件

模块: gulp,gulp-sass

示例:

 //获取gulp对象
 const gulp = require("gulp")
 //获取压缩 sass文件的对象
 const gulpSass = require("gulp-sass")
 // 定义压缩文件的处理方法
 function sass(){
     //1. 匹配要所有压缩的sass文件
     gulp.src('sass/*.scss')
     //2. 压缩文件
    .pipe(gulpSass())
     //3. 将压缩后的文件写入指定目录
    .pipe(gulp.dest('dist/sass'))
 }
 //升级:自动监听文件的改变,
 //创建监听sass文件的方法
 function autoSass(){
     // 创建监听对象
     var watcher = gulp.watch("sass/*.scss");
     //分别监听 change,add,unlink事件
     watcher.on("change",function(path,stats){
         console.log(`${path} has been changed!`);
    });
     watcher.on("add",function(path,stats){
         console.log(`${path} has been add!`);
    });
     watcher.on("unlink",function(path,stats){
         console.log(`${path} has been unlink!`);
    });
     watcher.on("error",function(error){
         console.log(error);
    })
 }
 //将定义好的压缩方法暴露给外界,并作为gulp的默认值
 // exports.images = gulp.series(images,autoImages);
 exports.autoSass = gulp.parallel(sass,autoSass);

完整项目目录:gulp-demo(编译sass)

注意:所有的项目,下载之后先在项目根目录要运行 npm i命令安装模块

以上就是前端必会的轻量打包工具gulp使用详解的详细内容,更多关于前端轻量打包工具gulp的资料请关注脚本之家其它相关文章!

相关文章

  • node.js中的querystring.parse方法使用说明

    node.js中的querystring.parse方法使用说明

    这篇文章主要介绍了node.js中的querystring.parse方法使用说明,本文介绍了querystring.parse的方法说明、语法、接收参数、使用实例和实现源码,需要的朋友可以参考下
    2014-12-12
  • 关于Node.js中Buffer的一些你可能不知道的用法

    关于Node.js中Buffer的一些你可能不知道的用法

    网上关于Node.js中Buffer用法的文章有很多,但是感觉还是不够详细,所以这篇文章主要介绍了关于Node.js中Buffer的一些你可能不知道的用法,文中介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-03-03
  • 浅谈Node.js中的定时器

    浅谈Node.js中的定时器

    本文给大家分享的是Node.js中的定时器的相关资料,十分的全面细致,有需要的小伙伴可以参考下。
    2015-06-06
  • 用Node提供静态文件服务的方法

    用Node提供静态文件服务的方法

    这篇文章主要介绍了用Node提供静态文件服务的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-07-07
  • node.js中的fs.readFileSync方法使用说明

    node.js中的fs.readFileSync方法使用说明

    这篇文章主要介绍了node.js中的fs.readFileSync方法使用说明,本文介绍了fs.readFileSync的方法说明、语法、接收参数、使用实例和实现源码,需要的朋友可以参考下
    2014-12-12
  • Lua表达式和控制结构学习笔记

    Lua表达式和控制结构学习笔记

    这篇文章主要介绍了Lua表达式和控制结构学习笔记,本文讲解了算术操作符、关系操作符、逻辑操作符、局部变量与作用域、控制结构等内容,需要的朋友可以参考下
    2014-12-12
  • Node.js实现http请求服务与Mysql数据库操作方法详解

    Node.js实现http请求服务与Mysql数据库操作方法详解

    这篇文章主要介绍了Node.js实现http请求服务与Mysql数据库操作方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2022-10-10
  • Node.js中的模块路径解析规则和子模块包

    Node.js中的模块路径解析规则和子模块包

    NodeJS特性如事件驱动、异步编程、无阻塞IO,这些特性为它带来了高效的性能和更少的代码,require函数支持斜杠(/)或盘符(C:)开头的绝对路径,也支持./开头的相对路径,为了便于管理和使用,我们可以把由多个子模块组成的大模块称做包,并把所有子模块放在同一个目录里
    2023-11-11
  • ndm:NPM的桌面GUI应用程序

    ndm:NPM的桌面GUI应用程序

    今天小编就为大家分享一篇关于ndm:NPM的桌面GUI应用程序,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-10-10
  • nodejs和npm版本不匹配:ERROR: npm v9.5.1 is known not to run on Node.js

    nodejs和npm版本不匹配:ERROR: npm v9.5.1 is known not to run

    本文主要介绍了nodejs和npm版本不匹配:ERROR: npm v9.5.1 is known not to run on Node.js,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06

最新评论