2024年最新天天用 webpack 你还记得 gulp 是啥吗,近期有面试的必看

最后

为了帮助大家更好的了解前端,特别整理了《前端工程师面试手册》电子稿文件。

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

  1. 使用 Gulp 之前,先在全局安装 gulp-cli

安装 gulp 命令行工具

npm i -g gulp-cli

验证安装是否成功

gulp -v

  1. 初始化项目

创建项目目录

mkdir project-name

进入项目目录

cd project-name

初始化项目

npm init --yes

  1. 安装 Gulp 包

安装 gulp 包,作为开发时依赖项

npm i gulp -D

  1. 创建 gulpfile 文件

gulpfile 文件是项目根目录下的 gulpfile.js在运行 gulp 命令时会被自动加载。在这个文件中,你经常会看到类似 src()dest()series()parallel() 函数之类的 Gulp API,除此之外,纯 JavaScript 代码或 Node.js 模块也会被使用。任何导出( exports )的函数都将注册到 Gulp 的任务(task)系统中。

创建任务,任务结束后,需要通过回调函数去标记

exports.foo = () => {

console.log(‘foo task is running’)

}

报错:

The following tasks did not complete: task

Did you forget to signal async completion?

解释:在最新的 Gulp 中,取消了同步代码模式。约定每个任务都必须是一个异步任务

解决:再函数参数中,设定回调函数(回调函数是异步操作)

  1. 在 gulpfile.js 中注册 Gulp 任务

创建任务,并导出任务

exports.foo = cb => {

console.log(‘foo task is running’)

cb()

}

旧版 Gulp 注册任务的语法(无需执行导出操作)

gulp.task(‘foo’, function(cb) {

console.log(‘foo task is running’)

cb()

});

  1. 运行 Gulp 任务

运行 foo 任务

如需运行多个任务(task),可以执行 gulp

gulp foo

  1. 创建默认任务

默认任务的名称是 default

exports.default = cb => {

console.log(‘default task is running’)

cb()

}

运行默认任务, gulp 后无需指定任务名称

gulp # 效果等同于 gulp default

组合任务

Gulp 提供了两个强大的组合方法: series()parallel()

如果需要让任务(task)按顺序执行,请使用 series() 方法(相当于 npm scripts 中的 && )。

如果希望任务(tasks)并行执行,可以使用 parallel() 方法将它们组合起来(相当于 npm scripts 中的 & )。

const gulp = require(‘gulp’)

const task1 = cb => {

setTimeout(() => {

console.log(‘Task 1 is running’)

cb()

}, 1000)

}

const task2 = cb => {

setTimeout(() => {

console.log(‘Task 2 is running’)

cb()

}, 1000)

}

const task3 = cb => {

setTimeout(() => {

console.log(‘Task 3 is running’)

cb()

}, 1000)

}

串行方式执行任务,先执行task1, 然后执行task2, 然后执行task3

exports.foo = gulp.series(task1, task2, task3)

并行方式执行任务,同时执行task1,task2,task3

exports.bar = gulp.parallel(task1, task2, task3)

执行命令

gulp foo # 串行执行

gulp bar # 并行执行

series()parallel() 可以被嵌套到任意深度。通过这两个函数,构建任务可以被任意排列组合,从而满足各种复杂的构建需求。

文件操作

gulp 暴露了 src()dest() 方法用于处理计算机上存放的文件。在代码构建过程中,需要将源文件,写入到目标目录。

通过 解构 的方式引入 gulp 中的函数

const { src, dest } = require(‘gulp’)

exports.default = () => {

// 文件操作

// 将 src/styles 目录下的 main.css 文件,复制到 dist/styles 目录下

return src(‘src/styles/main.less’, { base: ‘src’ }).pipe(dest(‘dist’))

}

执行命令

gulp default

或直接执行

gulp

案例演示


样式文件构建

对样式文件进行转换、压缩、重命名。

安装相关的 Gulp 插件

npm i gulp-less -D

npm i gulp-autoprefixer -D

npm i gulp-clean-css -D

npm i gulp-rename -D

在 gulpfile.js 中添加样式编译内容

const gulp = require(‘gulp’)

const less = require(‘gulp-less’)

// 给 CSS 属性添加前缀的插件(详情请看下方 CSS Hack)

const autoprefixer = require(‘gulp-autoprefixer’)

// 压缩 CSS 的插件

const cleanCss = require(‘gulp-clean-css’)

// 重命名转换文件的插件

const rename = require(‘gulp-rename’)

const style = () => {

return src(‘src/styles/*.less’, { base: ‘src’ })

.pipe(less())

.pipe(autoprefixer())

.pipe(cleanCss())

.pipe(rename({extname: ‘.min.css’}))

.pipe(dest(‘dist’))

}

module.exports = {

style

}

运行命令

npm gulp style

通过样式文件的构建,我们可以更清晰的理解文件操作。

CSS Hack

由于不同浏览器中的渲染引擎不同,这导致了同一段 CSS 代码,在不同的浏览器上解析效果不同(即 CSS 代码具有兼容性问题)。

针对不同浏览器,写不同 CSS 代码的过程称为 CSS Hack

CSS Hack 有三种形式:CSS 属性 Hack、CSS选择符 Hack 和 IE条件注释 Hack( Hack主要针对IE浏览器 )

  • 属性级 Hack
比如 IE6 能识别下划线“`_`”和星号“`*`”,IE7 能识别星号“`*`”,但不能识别下划线”`_` ”
  • 选择符级 Hack
IE6 能识别 `*html .class{}`
IE7 能识别 `*+html .class{}` 或者 `*:first-child+html .class{}`
  • IE 条件注释 Hack:
# 针对 IE6 及以下版本:
<!--[if lt IE 6]>您的代码<![endif]-->
这类 Hack 不仅对 CSS 生效,对写在判断语句里面的所有代码都会生效。

本小节,只讨论属性级 Hack

不同浏览器的 CSS 属性前缀:

例如:use-select 存在兼容性问题。CSS 属性 Hack 的解决方案如下:

上述添加 CSS 属性前缀的操作,之前是通过程序员手动添加的。这类重复性操作,我们可以通过插件完成。

在 Gulp 中 gulp-autoprefixer 插件,可以根据 caniuse.com 上提供的 CSS 兼容性数据,自动地给 CSS 属性加前缀,以保证 CSS 代码的兼容性问题。

脚本文件构建

对 JS 代码进行 Babel 转换和压缩。

注意:因为不同 babel 版本对应的 gulp-babel 的安装命令不同,所以安装 gulp-babel 之前需要先确定本地 babel 版本 (通过 babel --version 查看)

Babel 7

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

Babel 6

$ npm install --save-dev gulp-babel@7 babel-core babel-preset-env

我本地的 babel 版本是 6,所以,执行 6 的安装命令

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

安装压缩脚本的插件

npm i gulp-uglify -D

在 gulpfile.js 中添加脚本编译内容

const rename = require(‘gulp-rename’)

const babel = require(‘gulp-babel’)

const uglify = require(‘gulp-uglify’)

const script = () => {

return src(‘src/scripts/*.js’, { base: ‘src’ })

.pipe(babel({

presets: [ ‘babel-preset-env’ ] // 不同版本的 babel,其转换规则写法也不同

}))

.pipe(uglify())

.pipe(rename({ “extname”: “.min.js” }))

.pipe(dest(‘dist’))

}

module.exports = {

style,

script

}

运行命令

gulp script

页面模板构建

对 html 文件的构建,主要指压缩 html 文件。其中 gulp-htmlmin 插件可以完成压缩任务。

gulp-htmlmin 插件的解析器是:https://github.com/kangax/html-minifier

想要查看 htmlmin 的使用参数,可以查看上述链接。

添加 htmlmin 插件

npm i gulp-htmlmin -D

在 gulpfile.js 中添加页面处理内容

const htmlmin = require(‘gulp-htmlmin’)

const html = () => {

return src(‘src/*.html’, { base: ‘src’ })

.pipe(htmlmin({

collapseWhitespace: true, // 去除标签之间多余的空行和空白

minifyCSS: true, // 压缩HTML中的CSS代码

minifyJS: true // 压缩HTML中的JS代码

}))

.pipe(dest(‘temp’))

}

module.exports = {

style,

script,

html

}

运行命令

gulp html

完成上述三个构建任务后,我们可以将 style,script 和 html 任务组合起来。因为 style,script 和 html 之间没有明确的前后顺序,所以,可以进行并行执行,并行执行可以提升构建效率。

引入 parallel 函数

const { src, dest, parallel } = require(‘gulp’)

// 任务的并行执行

const build = parallel(style, script, html)

module.exports = {

build

}

运行命令

gulp build

图片(字体)文件转换

对图片文件的构建,主要是指图片的压缩。通过 gulp-imagemin 插件可以完成图片的压缩任务。

安装 imagemin 插件

npm i gulp-imagemin -D

在 gulpfile.js 中引入图片压缩插件

const imagemin = require(‘gulp-imagemin’)

// 图片构建任务

const image = () => {

return src(‘src/images/**’, { base: ‘src’ })

.pipe(imagemin())

.pipe(dest(‘dist’))

}

// 图片构建任务,也可以与以上三个任务一起,并行执行

const build = parallel(style, script, html, image)

module.exports = {

image,

build

}

运行命令

gulp build

报错处理:

gulp-imagemin: Couldn’t load default plugin “gifsicle”

gulp-imagemin: Couldn’t load default plugin “optipng”

原因:npm 安装依赖失败

解决:

  1. 配置 hosts (详情参考本节最后的附录部分)
  1. 重新安装 npm i gulp-imagemin -D

文件清除

有时候,我们需要删除一些构建的历史文件,然后再重新构建。删除文件操作,可以通过 del 插件完成。

通过del插件来删除指定文件

npm i del -D

const del = require(‘del’)

// 声明清除任务

const clean = () => {

return del([‘dist’])

}

// 编译之前,先执行clean,删除历史文件

const build = parallel(style, script, html, image)

const dev = series(clean, build)

module.exports = {

clean,

dev

}

运行命令,查看文件是否删除

gulp clean

或者

gulp dev

开发服务器

通过web服务器插件,将 dist 下的代码,发布到浏览器查看效果。发布web服务的插件有很多。这里,我们推荐功能强大的 browser-sync。

安装 browser-sync 插件

npm i browser-sync -D

在 gulpfile.js 中添加开发服务器的内容

const browserSync = require(‘browser-sync’)

const bs = browserSync.create()

// 声明 web 服务构建任务

const serve = () => {

bs.init({

server: {

baseDir: ‘./dist’ // 指定服务启动的目录

routes: {

‘/node_modules’: ‘node_modules’ // 引入 Bootstrap 是设置路径映射

}

最后

前15.PNG

前16.PNG

由于文档内容过多,为了避免影响到大家的阅读体验,在此只以截图展示部分内容

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

dev = series(clean, build)

module.exports = {

clean,

dev

}

运行命令,查看文件是否删除

gulp clean

或者

gulp dev

开发服务器

通过web服务器插件,将 dist 下的代码,发布到浏览器查看效果。发布web服务的插件有很多。这里,我们推荐功能强大的 browser-sync。

安装 browser-sync 插件

npm i browser-sync -D

在 gulpfile.js 中添加开发服务器的内容

const browserSync = require(‘browser-sync’)

const bs = browserSync.create()

// 声明 web 服务构建任务

const serve = () => {

bs.init({

server: {

baseDir: ‘./dist’ // 指定服务启动的目录

routes: {

‘/node_modules’: ‘node_modules’ // 引入 Bootstrap 是设置路径映射

}

最后

[外链图片转存中…(img-RI2cEbQk-1715749474020)]

[外链图片转存中…(img-m0RYkwxE-1715749474021)]

由于文档内容过多,为了避免影响到大家的阅读体验,在此只以截图展示部分内容

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值