一会带你学会用Webpack搭建开发环境并打包代码

 更新时间:2023年08月29日 09:01:02   作者:小周不摆烂  
这篇文章主要给大家介绍了关于如何用Webpack搭建开发环境并打包的相关资料,webpack是一个现代JavaScript应用程序的静态模块打包器(module bundler),需要的朋友可以参考下

搭建开发环境

问题:之前改代码,需重新打包才能运行查看,效率很低

开发环境: 配置 webpack-dev-server 快速开发应用程序

作用:启动 Web 服务, 自动 检测代码变化, 热更新 到网页

注意:dist 目录和打包内容是在内存里(更新快)

步骤:

1. 下载 webpack-dev-server 软件包到当前项目

2. 设置模式 为 开发模式 ,并配置 自定义命令

3. 使用 npm run dev 来启动开发服务器,试试热更新效果

打包模式

打包模式:告知 Webpack 使用相应模式的内置优化

分类:

设置: 方式1:在 webpack.config.js 配置文件设置 mode 选项 

方式2:在 package.json 命令行设置 mode 参数

注意:命令行设置的优先级高于配置文件中的,推荐用命令行设置

打包模式的应用  

需求:在开发模式下用 style-loader 内嵌更快,在生产模式下提取 css 代码

方案1: webpack.config.js 配置导出函数,但是局限性大(只接受 2 种模式)

方案2:借助 cross-env (跨平台通用)包命令,设置参数区分环境

步骤:

1. 下载 cross-env 软件包到当前项目

2. 配置 自定义命令,传入参数名和值(会绑定到 process.env 对象下)

3. 在 webpack.config.js 区分不同环境 使用 不同配置

4. 重新打包观察两种配置区别

方案3: 配置不同的 webpack.config.js (适用多种模式差异性较大情况)

前端-注入环境变量

需求: 前端 项目中,开发模式下打印语句生效,生产模式下打印语句失效

问题:cross-env 设置的只在 Node.js 环境生效,前端代码无法访process.env.NODE_ENV

解决 :使用 Webpack 内置的 DefinePlugin 插件

作用:在编译时,将前端代码中匹配的变量名,替换为值或表达式

DefinePlugin 

DefinePlugin  允许在 编译时 将你代码中的变量替换为其他值或表达式。这在需要根据开发模式与生产模式进行不同的操作时,非常有用。例如,如果想在开发构建中进行日志记录,而不在生产构建中进行,就可以定义一个全局常量去判断是否记录日志。这就是  DefinePlugin  的发光之处,设置好它,就可以忘掉开发环境和生产环境的构建规则。

new webpack.DefinePlugin({  // 定义...});

Usage 

传递给  DefinePlugin  的每个键都是一个标识符或多个以  .  连接的标识符。

  • 如果该值为字符串,它将被作为代码片段来使用。
  • 如果该值不是字符串,则将被转换成字符串(包括函数方法)。
  • 如果值是一个对象,则它所有的键将使用相同方法定义。
  • 如果键添加 typeof 作为前缀,它会被定义为 typeof 调用。

这些值将内联到代码中,从而允许通过代码压缩来删除冗余的条件判断

new webpack.DefinePlugin({
  PRODUCTION: JSON.stringify(true),
  VERSION: JSON.stringify('5fa3b9'),
  BROWSER_SUPPORTS_HTML5: true,
  TWO: '1+1',
  'typeof window': JSON.stringify('object'),
  'process.env.NODE_ENV': JSON.stringify(process.env.NODE_ENV),
});

开发环境调错 - source map

问题:代码被压缩和混淆,无法正确定位源代码位置(行数和列数)

source map: 可以准确追踪 error 和 warning 在原始代码的位置

设置:webpack.config.js 配置 devtool 选项 inline-source-map 选项:把源码的位置信息一起打包在 js 文件内

注意:source map 仅适用于开发环境,不要在生产环境使用(防止被 轻易 查看源码位置)

解析别名 alias

解析别名: 配置模块如何解析,创建 import 引入路径的别名,来确保模块引入变得更简单

例如:原来路径如图,比较长而且相对路径不安全

解决:在 webpack.config.js 中配置解析别名 @ 来代表 src 绝对路径

优化-CDN使用 

CDN定义 :内容分发网络,指的是一组分布在各个地区的服务器

作用:把静态资源文件/第三方库放在 CDN 网络中各个服务器中,供用户就近请求获取

好处:减轻自己服务器请求压力,就近请求物理延迟低,配套缓存策略

步骤:

1. 在 html 中引入第三方库的 CDN 地址 并用模板语法判断

2. 配置 webpack.config.js 中 externals 外部扩展选项(防止某些 import 的包被打包)

3. 两种模式下打包观察效果

多页面打包 

单页面 : 单个 html 文件,切换 DOM 的方式实现不同业务逻辑展示,后续 Vue/React 会学到

多页面: 多个 html 文件,切换页面实现不同业务逻辑展示

需求:把黑马头条-数据管理平台-内容页面一起引入打包使用

步骤:

1. 准备 源码 (html,css,js)放入相应位置,并改用模块化语法 导出

2. 下载 form-serialize 包并 导入 到核心代码中使用

3. 配置 webpack.config.js 多入口 和 多页面 的设置

4. 重新打包观察效果

优化-分割公共代码 

需求:把 2 个以上页面引用的公共代码提取

步骤:

1. 配置 webpack.config.js 的 splitChunks 分割功能

2. 打包 观察效果

总结

到此这篇关于用Webpack搭建开发环境并打包代码的文章就介绍到这了,更多相关Webpack搭建开发环境并打包内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Node.js fs模块(文件模块)创建、删除目录(文件)读取写入文件流的方法

    Node.js fs模块(文件模块)创建、删除目录(文件)读取写入文件流的方法

    这篇文章主要介绍了Node.js fs模块(文件模块)创建、删除目录(文件)读取写入文件流的方法,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-09-09
  • 使用node.js搭建服务器

    使用node.js搭建服务器

    最近需要完成一个课程设计,被项目经理(组长)分配写界面功能,下面小编通过本文给大家分享使用使用node搭建小型服务器的方法,需要的朋友参考下
    2017-05-05
  • 使用travis-ci如何持续部署node.js应用详解

    使用travis-ci如何持续部署node.js应用详解

    最近在学习使用 travis-ci 对项目进行持续集成测试,所以下面这篇文章主要给大家介绍了关于使用travis-ci如何持续部署node.js应用的相关资料,文中介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-07-07
  • 使用VS开发 Node.js指南

    使用VS开发 Node.js指南

    这篇文章主要介绍了使用VS开发 Node.js的方法,主要是使用NTVS(Node.js Toolsfor Visual Studio)来实现,有需要的小伙伴参考下
    2015-01-01
  • nodejs文件操作模块FS(File System)常用函数简明总结

    nodejs文件操作模块FS(File System)常用函数简明总结

    这篇文章主要介绍了nodejs文件操作模块FS(File System)常用函数简明总结,对FS模块的大部份异步函数做了介绍,而且用中文注释,这下用起来方便了,需要的朋友可以参考下
    2014-06-06
  • node.js中对Event Loop事件循环的理解与应用实例分析

    node.js中对Event Loop事件循环的理解与应用实例分析

    这篇文章主要介绍了node.js中对Event Loop事件循环的理解与应用,结合实例形式分析了node.js中Event Loop事件循环相关原理、使用方法及操作注意事项,需要的朋友可以参考下
    2020-02-02
  • Nodejs访问网络并解析返回的json的实现方法

    Nodejs访问网络并解析返回的json的实现方法

    本文主要介绍了Nodejs访问网络并解析返回的json的实现方法,文中根据实例编码详细介绍的十分详尽,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • 配置nodejs环境的方法

    配置nodejs环境的方法

    本篇文章主要介绍了配置nodejs环境变量的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • 详解node Async/Await 更好的异步编程解决方案

    详解node Async/Await 更好的异步编程解决方案

    这篇文章主要介绍了详解Async/Await 更好的异步编程解决方案,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-05-05
  • nodejs取得当前执行路径的方法

    nodejs取得当前执行路径的方法

    今天小编就为大家分享一篇nodejs取得当前执行路径的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-05-05

最新评论