前端工程化--gulp的使用

gulp

介绍

  • gulp 是一个基于 Nodejs 的自动化构建工具,中文主页
  • 能自动化地完成 javascript/coffee/sass/less/html/image/css 等文件的合并、压缩、检查、监听文件变化、浏览器自动刷新、测试等任务

使用步骤:

  1. 安装 nodejs

  2. 全局安装 gulp

    npm install gulp -g
    
  3. 局部安装gulp

    npm install gulp --save-dev
    
  4. 创建一个简单的应用,文件结构如下:

    |- gulpfile.js  // gulp配置文件
    |- package.json
    
  5. 配置编码: gulpfile.js

    //引入gulp模块
    const gulp = require('gulp');
    //定义任务
    gulp.task('任务名', function() {// 将任务代码放在这
    });
    
  6. 构建命令:

    gulp 任务名
    

    The following tasks did not complete: default

    Did you forget to signal async completion?

    错误的解决方法:

    1. 返回一个可读流
    2. 传入一个回调并执行
    3. 回调函数设置为 async 函数

gulp 插件

gulp 插件是专门针对 gulp 开发的工具包(npm包),用来实现特定的功能。

gulp-jshint 语法检查:

JSHint 是一个 JavaScript 的代码质量检查工具。gulp-jshint 是为 gulp 封装的插件

使用步骤:

  1. 安装插件

    npm install jshint gulp-jshint --save-dev
    
  2. 创建配置文件 .jshintrc
    (选项配置地址 https://jshint.com/docs/options/)

    {"esversion": 6,  "asi":true,				// 允许不写结尾处的分号"undef": true, 			// 使用之前必须定义"devel": true, 			// 没有定义也可以使用 console,alert 进行调试"eqeqeq": true,			// 强制使用 === "unused": true, 		// 定义了必须使用"globals": { 			// 配置全局变量,直接使用不会报错"$": true }
    }
    
  3. gulpfile.js 引入 jshint

    const jshint = require('gulp-jshint')
    
  4. 定义任务

    gulp.task('jshint', function() {// 任务代码return gulp.src('./src/js/*.js').pipe(jshint()).pipe(jshint.reporter('default'));
    });
    
  5. 运行命令

    gulp jshint 
    
gulp-babel 语法转换

Babel 是一个 JavaScript 编译器,可以将新的 JS 语法(ES6、7、8)转化为浏览器识别的 ES5 语法。
gulp-babel 是 babel 为 gulp 封装的插件

  1. 安装插件:

    npm install --save-dev gulp-babel @babel/core @babel/preset-env
    

    @babel/core 是 babel 的核心包

    @babel/preset-env 预设的包 (babel-preset-es2015)

  2. gulpfile.js 引入:

    const babel = require('gulp-babel');
    
  3. 定义任务:

    gulp.task('babel', () => {return gulp.src('./src/js/*.js').pipe(babel({ //进行语法转换presets: ['@babel/env']})).pipe(gulp.dest('build/js'))//输出到指定目录
    });
    
  4. 运行命令:

    gulp babel
    

经过 babel 转换后的 ES6 模块化语法变成了 CommonJs 语法,还需要用 browserify 转换

gulp-browserify 转换 CommonJs 模块化语法
  1. 安装插件:

    npm install --save-dev gulp-browserify
    
  2. 安装插件(用于重命名)

    npm install --save-dev gulp-rename
    
  3. 引入:

    const browserify = require('gulp-browserify');
    const rename = require('gulp-rename');
    
  4. 定义任务:

    gulp.task('browserify', function() {return gulp.src('./build/js/index.js').pipe(browserify())					//将CommonJs语法转换为浏览器能识别的语法.pipe(rename('built.js'))			//为了防止冲突将文件重命名.pipe(gulp.dest('build/js'))		//输出到指定位置
    });
    
  5. 运行命令

    gulp browserify
    
配置默认任务,让多个任务依次执行

定义默认任务

gulp.task('default', gulp.series('jshint', 'babel', 'browserify'));
gulp-uglify 压缩 JavaScript
  1. 安装插件

    npm install --save-dev gulp-uglify
    
  2. 引入插件

    const uglify = require('gulp-uglify');
    
  3. 定义任务

    gulp.task('uglify', function () {return gulp.src('build/js/built.js').pipe(uglify())  //压缩js.pipe(rename('dist.min.js')).pipe(gulp.dest('dist/js'))
    });
    
  4. 运行命令

    gulp uglify
    
gulp-less 编译 less 文件及使用 less-plugin-autoprefix 扩展前缀
  1. 安装插件

    npm install gulp-less less-plugin-autoprefix
    
  2. 引入插件

    const less = require('gulp-less');
    const LessAutoprefix = require('less-plugin-autoprefix');
    const autoprefix = new LessAutoprefix({ browsers: ['last 2 versions'] });
    
  3. 定义任务:

    gulp.task('less', function () {return gulp.src('./src/css/*.less').pipe(less({plugins: [autoprefix]//自动扩展前缀})).pipe(gulp.dest('./build/css'));
    });
    
  4. 运行命令:

    gulp less 
    
使用 gulp-concat 合并 CSS 文件
  1. 安装插件

    npm install --save-dev gulp-concat
    
  2. 引入

    const concat = require('gulp-concat');
    
  3. 定义任务

    gulp.task('concat', function () {return gulp.src('./build/css/*.css').pipe(concat('built.css')).pipe(gulp.dest('./build/css/concat'));
    });
    
  4. 运行命令:gulp concat

gulp-cssmin 压缩 CSS 文件
  1. 安装插件:

    npm install --save-dev gulp-cssmin
    
  2. 引入

    const cssmin = require('gulp-cssmin');
    
  3. 定义任务

    gulp.task('cssmin', function () {return gulp.src('build/css/concat/built.css').pipe(cssmin()).pipe(rename('dist.min.css')).pipe(gulp.dest('dist/css'));
    });
    
gulp-htmlmin 压缩 HTML 文件
  1. 安装插件
    npm install --save gulp-htmlmin
    
  2. 引入
    const htmlmin = require('gulp-htmlmin');
    
  3. 定义任务
    gulp.task('htmlmin', () => {return gulp.src('src/index.html').pipe(htmlmin({collapseWhitespace: true ,//去除空格removeComments:true //去除注释})).pipe(gulp.dest('dist'));
    });
    
自动化配置
  1. 安装模块

    npm install gulp-livereload gulp-connect opn --save-dev
    
  2. 引入模块

    const livereload = require('gulp-livereload');
    const connect = require('gulp-connect');
    const opn = require('opn');
    
  3. 自动执行任务,编译代码

    //1. 在所有可能要执行任务后面加上 .pipe(livereload());
    gulp.task('watch', function () {//2. 启动热加载服务livereload.listen();//3. 通过自己服务器打开项目,自动刷新connect.server({root: 'dist',port: 3000,livereload: true  // 自动刷新});//3. 自动打开浏览器opn('http://localhost:3000/index.html');//4. 监视指定文件(第一个参数),一旦文件发生变化,就自动执行后面的任务(第二个参数)gulp.watch('src/css/*.less', gulp.series(['less', 'concat', 'cssmin']));gulp.watch('./src/js/*.js', gulp.series(['jshint', 'babel', 'browserify', 'uglify']));gulp.watch('./src/index.html', gulp.series('htmlmin'));
    });
    

备注:必须要在 src 文件夹中修改 index.html 中引入样式和脚本的路径,gulp 不会自动处理路径。

相关插件:

  • gulp-concat : 合并文件(js/css)
  • gulp-uglify : 压缩js文件
  • gulp-rename : 文件重命名
  • gulp-less : 编译less
  • gulp-livereload : 实时自动编译刷新

重要API

  • gulp.src(filePath/pathArr) :
    • 指向指定路径的所有文件, 返回文件流对象
    • 用于读取文件
  • gulp.dest(dirPath/pathArr)
    • 指向指定的所有文件夹
    • 用于向文件夹中输出文件
  • gulp.task(name, [deps], fn)
    • 定义一个任务
  • gulp.watch()
    • 监视文件的变化

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/42132.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Flutter完整开发实战详解(一、Dart语言和Flutter基础)

前言 在如今的 Flutter 大潮下,本系列是让你看完会安心的文章。本系列将完整讲述:如何快速从0开发一个完整的 Flutter APP,配套高完成度 Flutter 开源项目 GSYGithubAppFlutter。同时也会提供一些 Flutter 的开发细节技巧,并针对…

Spring 事件监听机制介绍以及源码分析

在复杂的业务系统中,模块间的过度耦合往往会导致代码维护困难、扩展性受限。Spring 事件监听机制基于观察者模式,提供了一种优雅的解耦方案,使得组件间通过事件驱动实现松耦合通信。这种机制不仅被 Spring 框架内部使用(如容器生命…

【VSCode的安装与配置】

目录: 一:下载 VSCode二:安装 VSCode三:配置 VSCode 一:下载 VSCode 下载地址:https://code.visualstudio.com/download 下载完成之后,在对应的下载目录中可以看到安装程序。 二:安装…

2024年认证杯SPSSPRO杯数学建模C题(第二阶段)云中的海盐全过程文档及程序

2024年认证杯SPSSPRO杯数学建模 C题 云中的海盐 原题再现: 巴黎气候协定提出的目标是:在2100年前,把全球平均气温相对于工业革命以前的气温升幅控制在不超过2摄氏度的水平,并为1.5摄氏度而努力。但事实上,许多之前的…

Scala基础语法与简介

对象 -对象有属性和行为。例如:一只狗的状属性有:颜色,名字,行为有:叫、跑、吃等。对象是一个类的实例。 类 -类是对象的抽象,而对象是类的具体实例。 方法 -方法描述的基本的行为,一个类可以…

鸿蒙UI开发

鸿蒙UI开发 本文旨在分享一些鸿蒙UI布局开发上的一些建议,特别是对屏幕宽高比发生变化时的应对思路和好的实践。 折叠屏适配 一般情况(自适应布局/响应式布局) 1.自适应布局 1.1自适应拉伸 左右组件定宽 TypeScript //左右定宽 Row() { …

BeeWorks:为企业打造专网部署即时通讯解决方案

在数字化快速发展的今天,企业的沟通与协作越来越依赖于高效的即时通讯工具。然而,保障信息安全和数据隐私也变得愈发重要。这种情况下,专网部署即时通讯软件成为许多企业的首要选择。BeeWorks作为一款优质的专网部署即时通讯软件,…

uniapp笔记-swiper组件实现轮播图

思路 主要就是参考 swiper | uni-app官网 实现轮播图。 实例 新建一个banner.vue通用组件。 代码如下&#xff1a; <template><view>轮播图</view> </template><script> </script><style> </style> 随后在index.vue中导…

企业在人工智能创新与安全之间走钢丝

2025 年全球 AI/ML 工具使用量将激增&#xff0c;企业将 AI 融入运营之中&#xff0c;员工也将 AI 嵌入日常工作流程中。报告显示&#xff0c;企业对 AI/ML 工具的使用同比增长 3,000% 以上&#xff0c;凸显了各行各业迅速采用 AI 技术&#xff0c;以提升生产力、效率和创新水平…

vue - [Vue warn]: Duplicate keys detected: ‘0‘. This may cause an update error.

问题描述&#xff1a; vue项目中&#xff0c;对表单数组赋值时&#xff0c;控制台抛出警告&#xff1a; 问题代码&#xff1a; 问题分析&#xff1a; 1、Vue 要求每个虚拟 DOM 节点必须有唯一的 key。该警告信息通常出现在使用v-for循环的场景中&#xff0c;多个同级节点使用…

Containerd+Kubernetes搭建k8s集群

虚拟机环境设置&#xff0c;如果不是虚拟机可以忽略不看 1、安装配置containerd 1.1 添加 Kubernetes 官方仓库 安装cri-tools的时候需要用到 cat > /etc/yum.repos.d/kubernetes.repo << EOF [kubernetes] nameKubernetes baseurlhttps://mirrors.aliyun.com/kub…

ubuntu服务器server版安装,ssh远程连接xmanager管理,改ip网络连接。图文教程

ventoy启动服务器版iso镜像&#xff0c;注意看server名称&#xff0c;跟之前desktop版ubuntu不一样。没有gui界面。好&#xff0c;进入命令行界面。语言彻底没汉化了&#xff0c;选英文吧&#xff0c;别的更看不懂。 跟桌面版ubuntu类似&#xff0c;选择是否精简系统&#xff0…

QOpenGLWidget视频画面上绘制矩形框

一、QPainter绘制 在QOpenGLWidget中可以绘制&#xff0c;并且和OpenGL的内容叠在一起。paintGL里面绘制完视频后&#xff0c;解锁资源&#xff0c;再用QPainter绘制矩形框。这种方式灵活性最好。 void VideoGLWidget::paintGL() {glClear(GL_COLOR_BUFFER_BIT);m_program.bi…

蓝桥杯备考:真题之飞机降落(暴搜+小贪心)

我们最多有十架飞机&#xff0c;可以选择dfs暴力搜索&#xff0c;枚举每种情况 那么&#xff0c;我们降落的时候怎么确定新的起点也就是newend呢&#xff1f; 如果飞机飞到机场的时刻是大于原来的end的&#xff0c;我们就让tili作为newend 否则&#xff0c;我们就让end作为ne…

解决 Element UI 嵌套弹窗的状态管理问题!!!

解决 Element UI 嵌套弹窗的状态管理问题 &#x1f527; 问题描述 ❓ 在使用 Element UI 开发一个多层嵌套弹窗功能时&#xff0c;遇到了以下问题&#xff1a; 弹窗只能打开一次&#xff0c;第二次点击无法打开 &#x1f6ab;收到 Vue 警告&#xff1a;避免直接修改 prop 值…

实时图像处理:让你的应用更智能

一、项目背景 在数字化飞速发展的今天&#xff0c;图像处理技术已成为众多领域不可或缺的核心组件。从医疗影像的精准诊断&#xff0c;到自动驾驶汽车对道路环境的实时感知&#xff0c;再到安防系统中对异常行为的迅速捕捉&#xff0c;实时图像处理正以惊人的速度改变着我们的…

AWVS中lodash如何验证

作为一名漏扫攻城狮&#xff0c;时不时会在AWVS中看到lodash这个漏洞&#xff0c;但是我只管导出报告&#xff0c;该怎么验证呢&#xff1f; 验证POC 下面就是用于验证的POC&#xff0c;把这个html中的src进行修改为扫描的网站中的lodash.min.js然后浏览器打开 <!DOCTYPE …

【算法学习计划】贪心算法(上)

目录 前言&#xff08;什么是贪心&#xff09; leetcode 860.柠檬水找零 leetcode 2208.将数组和减半的最少操作次数 leetcode 179.最大数 leetcode 376.摆动序列 leetcode 300.最长递增子序列 leetcode 334.递增的三元子序列 leetcode 674.最长连续递增序列 leetcode …

Ubuntu 22.04 安装向日葵远程控制

1. 前言 由于公司客户的服务器用是图形化桌面&#xff0c;所以我们需要一个远程控制工具来控制服务器&#xff0c;目前市面上两款比较热门的控制软件就是ToDesk和向日葵了&#xff0c;我们今天就来学习一下向日葵的使用 2. 下载软件 前往向日葵官网下载 向日葵远程控制app官…

Linux网络编程(七)——套接字的多种可选项

文章目录 7 套接字的多种可选项 7.1 套接字可选项和I/O缓冲大小 7.1.1 套接字多种可选项 7.1.2 getsockopt & setsockopt 7.1.3 SO_SNDBUF & SO_RCVBUF 7.2 地址再分配 SO_REUSEADDR 7.2.1 发生地址分配错误&#xff08;Binding Error&#xff09; 7.2.2 Time-…